@hydra-acp/cli 0.1.68 → 0.1.69
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.js +226 -206
- package/dist/index.d.ts +2 -0
- package/dist/index.js +68 -48
- package/package.json +1 -1
package/dist/cli.js
CHANGED
|
@@ -1,14 +1,16 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
var
|
|
3
|
-
`,{encoding:"utf8",mode:384})}async function Or(){let t=await
|
|
4
|
-
`),e}var mt=V(()=>{"use strict";ue()});import*as qt from"fs/promises";import*as nl from"fs";import{randomBytes as
|
|
5
|
-
`;await
|
|
6
|
-
`)}async function Z(){return await Fi(),ol.parse(await _i())}async function
|
|
7
|
-
`),o(),e(i);return}if(l===3){o(),n(new Error("password entry cancelled"));return}if(l===127||l===8){i=i.slice(0,-1);continue}i+=String.fromCharCode(l)}},d=c=>{o(),n(c)};s.setRawMode(!0),s.resume(),s.on("data",a),s.on("error",d)}):
|
|
8
|
-
`);o!==-1&&(process.stdin.removeListener("data",s),process.stdin.removeListener("error",r),t(n.slice(0,o).replace(/\r$/,"")))},r=i=>{process.stdin.removeListener("data",s),process.stdin.removeListener("error",r),e(i)};process.stdin.on("data",s),process.stdin.on("error",r)})}var $a=V(()=>{"use strict"});import*as yl from"path";function Pn(){let t=process.argv[1];if(!t)return"hydra-acp";let e=yl.basename(t);return e==="cli.js"||e==="cli"?"hydra-acp":e}var Ni=V(()=>{"use strict"});import*as bl from"os";async function Wt(t){let e=await Or(),n=t.daemon.host,s=t.daemon.port,r=!!t.daemon.tls,i=r?"https":"http",o=r?"wss":"ws";return{baseUrl:`${i}://${n}:${s}`,wsUrl:`${o}://${n}:${s}/acp`,token:e,display:`${n}:${s}`,isLocal:on(n)}}function _a(t,e){let{httpScheme:n,wsScheme:s}=Ta(t.host);return{baseUrl:`${n}://${t.host}:${t.port}`,wsUrl:`${s}://${t.host}:${t.port}/acp`,token:e,display:Il(t),isLocal:t.isLoopback}}async function vl(t,e={}){let n=e.fetchImpl??fetch,s=e.promptImpl??Ds,r=e.preferServiceToken??!0,i=e.allowPrompt??!0;if(t.isLoopback&&r){let g=await Os();if(g)return _a(t,g)}let o=e.store??await Bi.load(),a=o.get(t.host,t.port);if(a)return _a(t,a.token);if(!i)throw new Fa(t.host,t.port);let d=Il(t),c=await s(`Password for ${d}: `);if(c.length===0)throw new Error("Password is required to attach to a remote daemon.");let{httpScheme:l}=Ta(t.host),f=`${l}://${t.host}:${t.port}`,u=await n(`${f}/v1/auth/login`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({password:c,label:wl()})});if(u.status===401)throw new Error(`Wrong password for ${d}.`);if(u.status===403)throw new Error(`No password is configured on ${d}. Run \`hydra-acp auth password\` on the daemon host first.`);if(u.status===429)throw new Error(`Too many failed login attempts on ${d}; try again later.`);if(!u.ok)throw new Error(`Login to ${d} failed: HTTP ${u.status}`);let p=await u.json();if(!p.session_token||!p.expires_at)throw new Error(`Login to ${d} returned a malformed response.`);return await o.set(t.host,t.port,{token:p.session_token,expiresAt:p.expires_at,label:wl()}),_a(t,p.session_token)}function wl(){try{let t=bl.hostname();return t.length>0?t:"remote"}catch{return"remote"}}function Il(t){let e=t.isLoopback?Bs:443;return t.port===e?t.host:`${t.host}:${t.port}`}var Fa,Hs=V(()=>{"use strict";Ne();mt();Br();gl();$a();Ni();Br();Fa=class extends Error{host;port;constructor(e,n){let s=n===443?"":`:${n}`;super(`No cached credentials for ${e}:${n}. Run \`${Pn()} --session hydra://${e}${s}/\` once in a terminal to log in.`),this.name="NoCachedCredentialError",this.host=e,this.port=n}}});import{z as A}from"zod";function wt(t){if(!t)return{};let e=t[Ct];if(!e||typeof e!="object"||Array.isArray(e))return{};let n=e,s={};if(typeof n.upstreamSessionId=="string"&&(s.upstreamSessionId=n.upstreamSessionId),typeof n.agentId=="string"&&(s.agentId=n.agentId),typeof n.cwd=="string"&&(s.cwd=n.cwd),typeof n.clientId=="string"&&(s.clientId=n.clientId),typeof n.readonly=="boolean"&&(s.readonly=n.readonly),(n.replayMode==="instant"||n.replayMode==="drip")&&(s.replayMode=n.replayMode),typeof n.dripSpeed=="number"&&n.dripSpeed>0&&(s.dripSpeed=n.dripSpeed),(n.toolContent==="inline"||n.toolContent==="references")&&(s.toolContent=n.toolContent),n.detachStatus==="detached"&&(s.detachStatus=n.detachStatus),typeof n.title=="string"&&(s.title=n.title),Array.isArray(n.agentArgs)&&n.agentArgs.every(r=>typeof r=="string")&&(s.agentArgs=n.agentArgs),Array.isArray(n.transformers)&&n.transformers.every(r=>typeof r=="string")&&(s.transformers=n.transformers),n.resume){let r=Qg.safeParse(n.resume);r.success&&(s.resume=r.data)}if(typeof n.model=="string"&&(s.model=n.model),typeof n.currentModel=="string"&&(s.currentModel=n.currentModel),typeof n.currentMode=="string"&&(s.currentMode=n.currentMode),n.currentUsage){let r=Ql.safeParse(n.currentUsage);r.success&&(s.currentUsage=r.data)}if(typeof n.turnStartedAt=="number"&&n.turnStartedAt>0&&(s.turnStartedAt=n.turnStartedAt),Array.isArray(n.availableCommands)){let r=[];for(let i of n.availableCommands){if(!i||typeof i!="object"||Array.isArray(i))continue;let o=i;if(typeof o.name!="string")continue;let a={name:o.name};typeof o.description=="string"&&(a.description=o.description),r.push(a)}r.length>0&&(s.availableCommands=r)}if(n.prompt&&typeof n.prompt=="object"&&!Array.isArray(n.prompt)){let r=n.prompt,i={};typeof r.queueing=="boolean"&&(i.queueing=r.queueing),typeof r.cancelling=="boolean"&&(i.cancelling=r.cancelling),typeof r.updating=="boolean"&&(i.updating=r.updating),typeof r.amending=="boolean"&&(i.amending=r.amending),typeof r.pipelining=="boolean"&&(i.pipelining=r.pipelining),s.prompt=i}if(n.agents&&typeof n.agents=="object"&&!Array.isArray(n.agents)){let r=n.agents,i={};typeof r.list=="boolean"&&(i.list=r.list),typeof r.installProgress=="boolean"&&(i.installProgress=r.installProgress),s.agents=i}if(typeof n.mcpStdin=="boolean"&&(s.mcpStdin=n.mcpStdin),typeof n.interactive=="boolean"&&(s.interactive=n.interactive),typeof n.ancillary=="boolean"&&(s.ancillary=n.ancillary),Array.isArray(n.queue)){let r=[];for(let i of n.queue){if(!i||typeof i!="object"||Array.isArray(i))continue;let o=i,a=o.originator;if(typeof o.messageId!="string"||!a||typeof a.clientId!="string"||!Array.isArray(o.prompt)||typeof o.position!="number"||typeof o.enqueuedAt!="number")continue;let d={clientId:a.clientId};typeof a.name=="string"&&(d.name=a.name),typeof a.version=="string"&&(d.version=a.version),r.push({messageId:o.messageId,originator:d,prompt:o.prompt,position:o.position,enqueuedAt:o.enqueuedAt})}r.length>0&&(s.queue=r)}if(Array.isArray(n.availableModes)){let r=[];for(let i of n.availableModes){if(!i||typeof i!="object"||Array.isArray(i))continue;let o=i;if(typeof o.id!="string")continue;let a={id:o.id};typeof o.name=="string"&&(a.name=o.name),typeof o.description=="string"&&(a.description=o.description),r.push(a)}r.length>0&&(s.availableModes=r)}if(Array.isArray(n.availableModels)){let r=[];for(let i of n.availableModels){if(!i||typeof i!="object"||Array.isArray(i))continue;let o=i;if(typeof o.modelId!="string")continue;let a={modelId:o.modelId};typeof o.name=="string"&&(a.name=o.name),typeof o.description=="string"&&(a.description=o.description),r.push(a)}r.length>0&&(s.availableModels=r)}if((n.status==="live"||n.status==="cold")&&(s.status=n.status),typeof n.busy=="boolean"&&(s.busy=n.busy),typeof n.awaitingInput=="boolean"&&(s.awaitingInput=n.awaitingInput),typeof n.attachedClients=="number"&&(s.attachedClients=n.attachedClients),typeof n.importedFromMachine=="string"&&(s.importedFromMachine=n.importedFromMachine),typeof n.importedFromUpstreamSessionId=="string"&&(s.importedFromUpstreamSessionId=n.importedFromUpstreamSessionId),typeof n.parentSessionId=="string"&&(s.parentSessionId=n.parentSessionId),typeof n.forkedFromSessionId=="string"&&(s.forkedFromSessionId=n.forkedFromSessionId),typeof n.forkedFromMessageId=="string"&&(s.forkedFromMessageId=n.forkedFromMessageId),n.originatingClient&&typeof n.originatingClient=="object"&&!Array.isArray(n.originatingClient)&&typeof n.originatingClient.name=="string"){let r=n.originatingClient;s.originatingClient={name:r.name,...typeof r.version=="string"?{version:r.version}:{}}}return n.agentCapabilities!==void 0&&(s.agentCapabilities=n.agentCapabilities),s}function Wi(t,e){return{...t??{},[Ct]:e}}function zi(t,e){let n={attachedClients:t.attachedClients,status:t.status,busy:t.busy,awaitingInput:t.awaitingInput};return t.cwd!==void 0&&(n.cwd=t.cwd),t.title!==void 0&&(n.title=t.title),t.agentId!==void 0&&(n.agentId=t.agentId),t.upstreamSessionId!==void 0&&(n.upstreamSessionId=t.upstreamSessionId),t.currentModel!==void 0&&(n.currentModel=t.currentModel),t.currentUsage!==void 0&&(n.currentUsage=t.currentUsage),t.importedFromMachine!==void 0&&(n.importedFromMachine=t.importedFromMachine),t.importedFromUpstreamSessionId!==void 0&&(n.importedFromUpstreamSessionId=t.importedFromUpstreamSessionId),t.parentSessionId!==void 0&&(n.parentSessionId=t.parentSessionId),t.forkedFromSessionId!==void 0&&(n.forkedFromSessionId=t.forkedFromSessionId),t.forkedFromMessageId!==void 0&&(n.forkedFromMessageId=t.forkedFromMessageId),t.originatingClient!==void 0&&(n.originatingClient=t.originatingClient),t.interactive!==void 0&&(n.interactive=t.interactive),t.priority!==void 0&&t.priority>0&&(n.priority=t.priority),e&&(e.clientId!==void 0&&(n.clientId=e.clientId),e.currentMode!==void 0&&(n.currentMode=e.currentMode),e.agentArgs!==void 0&&e.agentArgs.length>0&&(n.agentArgs=e.agentArgs),e.availableCommands!==void 0&&e.availableCommands.length>0&&(n.availableCommands=e.availableCommands),e.availableModes!==void 0&&e.availableModes.length>0&&(n.availableModes=e.availableModes),e.availableModels!==void 0&&e.availableModels.length>0&&(n.availableModels=e.availableModels),e.turnStartedAt!==void 0&&(n.turnStartedAt=e.turnStartedAt),e.agentCapabilities!==void 0&&(n.agentCapabilities=e.agentCapabilities),e.queue!==void 0&&e.queue.length>0&&(n.queue=e.queue)),n}function Gl(t){let e={sessionId:t.sessionId,cwd:t.cwd,updatedAt:t.updatedAt,_meta:Wi(t._meta,zi(t))};return t.title!==void 0&&(e.title=t.title),e}var yt,B,zl,Yg,Jl,Qg,Kl,Ct,Vl,Yl,Ql,hA,Gg,gA,Xl,Ji,Zl,yA,wA,bA,eu,vA,tu,IA,nu,SA,kA,su,Ki,dt=V(()=>{"use strict";yt=1,B={ParseError:-32700,InvalidRequest:-32600,MethodNotFound:-32601,InvalidParams:-32602,InternalError:-32603,SessionNotFound:-32001,NotAuthorisedToAttach:-32002,MultiClientNotSupported:-32003,AgentNotInstalled:-32005,BundleAlreadyImported:-32010,PermissionDenied:-32011,AlreadyAttached:-32012,StreamNotEnabled:-32013,SessionClosing:-32014},zl=A.object({protocolVersion:A.number().optional(),clientCapabilities:A.record(A.unknown()).optional(),clientInfo:A.object({name:A.string(),version:A.string().optional()}).optional()}),Yg=A.enum(["full","pending_only","none","after_message"]),Jl=A.object({cwd:A.string(),mcpServers:A.array(A.unknown()).optional(),_meta:A.record(A.unknown()).optional()}),Qg=A.object({upstreamSessionId:A.string(),agentId:A.string(),cwd:A.string(),title:A.string().optional(),agentArgs:A.array(A.string()).optional()}),Kl=A.object({sessionId:A.string(),historyPolicy:Yg.default("full"),afterMessageId:A.string().optional(),clientId:A.string().optional(),clientInfo:A.object({name:A.string(),version:A.string().optional()}).optional(),_meta:A.record(A.unknown()).optional()}),Ct="hydra-acp";Vl=A.object({sessionId:A.string()}),Yl=A.object({cwd:A.string().optional(),cursor:A.string().optional()}),Ql=A.object({used:A.number().optional(),size:A.number().optional(),costAmount:A.number().optional(),costCurrency:A.string().optional()}),hA=A.object({sessionId:A.string(),upstreamSessionId:A.string().optional(),cwd:A.string(),title:A.string().optional(),agentId:A.string().optional(),currentModel:A.string().optional(),currentUsage:Ql.optional(),importedFromMachine:A.string().optional(),importedFromUpstreamSessionId:A.string().optional(),parentSessionId:A.string().optional(),forkedFromSessionId:A.string().optional(),forkedFromMessageId:A.string().optional(),originatingClient:A.object({name:A.string(),version:A.string().optional()}).optional(),interactive:A.boolean().optional(),priority:A.number().int().nonnegative().optional(),updatedAt:A.string(),attachedClients:A.number().int().nonnegative(),status:A.enum(["live","cold"]).default("live"),busy:A.boolean().default(!1),awaitingInput:A.boolean().default(!1),_meta:A.record(A.unknown()).optional()}),Gg=A.object({sessionId:A.string(),cwd:A.string(),title:A.string().optional(),updatedAt:A.string().optional(),_meta:A.record(A.unknown()).optional()}),gA=A.object({sessions:A.array(Gg),nextCursor:A.string().optional()});Xl=A.object({sessionId:A.string(),prompt:A.array(A.unknown()),_meta:A.record(A.unknown()).optional()}),Ji=A.object({sessionId:A.string()}),Zl=A.object({clientId:A.string(),name:A.string().optional(),version:A.string().optional()}),yA=A.object({sessionId:A.string(),messageId:A.string(),originator:Zl,prompt:A.array(A.unknown()),position:A.number().int().nonnegative(),queueDepth:A.number().int().positive(),enqueuedAt:A.number()}),wA=A.object({sessionId:A.string(),messageId:A.string(),prompt:A.array(A.unknown())}),bA=A.object({sessionId:A.string(),messageId:A.string(),reason:A.enum(["started","cancelled","abandoned"])}),eu=A.object({sessionId:A.string(),messageId:A.string()}),vA=A.object({cancelled:A.boolean(),reason:A.enum(["ok","not_found","already_running"])}),tu=A.object({sessionId:A.string(),messageId:A.string(),prompt:A.array(A.unknown())}),IA=A.object({updated:A.boolean(),reason:A.enum(["ok","not_found","already_running"])}),nu=A.object({sessionId:A.string(),targetMessageId:A.string(),prompt:A.array(A.unknown()),replaceQueue:A.boolean().optional(),onTargetCompleted:A.enum(["reject","send_anyway"]).optional()}),SA=A.object({amended:A.boolean(),reason:A.enum(["ok","target_completed","target_cancelled","target_not_found"]),messageId:A.string().optional()}),kA=A.object({sessionId:A.string(),cancelledMessageId:A.string(),newMessageId:A.string(),prompt:A.array(A.unknown()),originator:Zl,amendedAt:A.number()}),su=A.object({agentId:A.string(),version:A.string(),source:A.enum(["binary","npm"]),phase:A.enum(["download_start","download_progress","download_done","extract","install_start","installed"]),receivedBytes:A.number().optional(),totalBytes:A.number().optional(),packageSpec:A.string().optional()}),Ki="hydra-acp/agents/install_progress"});import{nanoid as Xg}from"nanoid";var Kt,Nr=V(()=>{"use strict";dt();Kt=class t{constructor(e){this.stream=e;this.stream.onMessage(n=>this.handleIncoming(n)),this.stream.onClose(n=>this.handleClose(n))}stream;requestHandlers=new Map;defaultRequestHandler;notificationHandlers=new Map;bufferedNotifications=new Map;static MAX_BUFFERED_PER_METHOD=64;pending=new Map;closed=!1;closeHandlers=[];orphanErrorHandlers=[];onRequest(e,n){this.requestHandlers.set(e,n)}setDefaultHandler(e){this.defaultRequestHandler=e}onNotification(e,n){this.notificationHandlers.set(e,n);let s=this.bufferedNotifications.get(e);if(s){this.bufferedNotifications.delete(e);for(let r of s)try{n(r.params,r.method)}catch{}}}drainBuffered(e){let s=this.bufferedNotifications.get(e)?.length??0;return this.bufferedNotifications.delete(e),s}onClose(e){this.closeHandlers.push(e)}onOrphanError(e){this.orphanErrorHandlers.push(e)}async request(e,n){return this.requestWithId(e,n).response}requestWithId(e,n){if(this.closed)return{id:"",response:Promise.reject(new Error("connection is closed"))};let s=Xg(),r={jsonrpc:"2.0",id:s,method:e,params:n},i=new Promise((o,a)=>{this.pending.set(s,{resolve:d=>o(d),reject:a}),this.stream.send(r).catch(d=>{this.pending.delete(s),a(d)})});return{id:s,response:i}}notify(e,n){if(this.closed)return Promise.resolve();let s={jsonrpc:"2.0",method:e,params:n};return this.stream.send(s)}async close(){this.closed||await this.stream.close()}fail(e){this.handleClose(e)}handleIncoming(e){"method"in e?"id"in e&&e.id!==void 0?this.handleRequest(e).catch(()=>{}):this.handleNotification(e):"id"in e?this.handleResponse(e):"error"in e&&this.handleResponse(e)}async handleRequest(e){let n=this.requestHandlers.get(e.method)??this.defaultRequestHandler;if(!n){await this.sendError(e.id,{code:B.MethodNotFound,message:`Method not found: ${e.method}`}).catch(()=>{});return}try{let s=await n(e.params,e.method),r={jsonrpc:"2.0",id:e.id,result:s};await this.stream.send(r).catch(()=>{})}catch(s){let r=s;await this.sendError(e.id,{code:r.code??B.InternalError,message:r.message,data:r.data}).catch(()=>{})}}handleNotification(e){let n=this.notificationHandlers.get(e.method);if(n){n(e.params,e.method);return}let s=this.bufferedNotifications.get(e.method);s||(s=[],this.bufferedNotifications.set(e.method,s)),s.push(e),s.length>t.MAX_BUFFERED_PER_METHOD&&s.shift()}handleResponse(e){let n=this.pending.get(e.id);if(!n){if(e.error)for(let s of this.orphanErrorHandlers)try{s({code:e.error.code,message:e.error.message,data:e.error.data})}catch{}return}if(this.pending.delete(e.id),e.error){let s=new Error(e.error.message);s.code=e.error.code,s.data=e.error.data,n.reject(s)}else n.resolve(e.result)}async sendError(e,n){let s={jsonrpc:"2.0",id:e,error:n};await this.stream.send(s)}handleClose(e){if(!this.closed){this.closed=!0;for(let n of this.pending.values())n.reject(e??new Error("connection closed"));this.pending.clear();for(let n of this.closeHandlers)n(e)}}}});import*as ou from"fs/promises";function ly(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}var sy,ry,zs,iy,oy,ay,dy,cy,iu,Qi,au=V(()=>{"use strict";sy=64*1024*1024,ry=1*1024*1024,zs=64*1024,iy=6e4,oy=100,ay=1e3,dy=64*1024,cy=256*1024,iu=20;Qi=class{storage;maxCapacityBytes;currentCapacityBytes;writeCursor=0;closed=!1;waiters=[];filePath;fileCapBytes;fileBytesWritten=0;fileCapReached=!1;onFileCapReached;logWriteError;fileWriteChain=Promise.resolve();constructor(e={}){if(this.maxCapacityBytes=e.capacityBytes??sy,this.maxCapacityBytes<=0)throw new Error("capacityBytes must be > 0");this.currentCapacityBytes=Math.min(ry,this.maxCapacityBytes),this.storage=Buffer.alloc(this.currentCapacityBytes),this.filePath=e.filePath,this.fileCapBytes=e.fileCapBytes??Number.POSITIVE_INFINITY,this.onFileCapReached=e.onFileCapReached,this.logWriteError=e.logWriteError}get capacity(){return this.maxCapacityBytes}get allocatedBytes(){return this.currentCapacityBytes}get writeCursorPos(){return this.writeCursor}get oldestAvailable(){return Math.max(0,this.writeCursor-this.currentCapacityBytes)}get isClosed(){return this.closed}append(e){this.closed||e.length===0||(this.writeRing(e),this.writeCursor+=e.length,this.filePath!==void 0&&this.scheduleFileWrite(e),this.wakeWaiters("data"))}close(){this.closed||(this.closed=!0,this.wakeWaiters("eof"))}read(e,n){let s=Math.max(0,Math.min(n,zs));if(s===0){let f={bytes:Buffer.alloc(0),nextCursor:e};return this.closed&&e>=this.writeCursor&&(f.eof=!0),f}let r=e,i=0,o=this.oldestAvailable;r<o&&(i=o-r,r=o);let a=this.writeCursor-r;if(a<=0){let f={bytes:Buffer.alloc(0),nextCursor:r};return i>0&&(f.gap=i),this.closed&&(f.eof=!0),f}let d=Math.min(a,s),l={bytes:this.sliceFromRing(r,d),nextCursor:r+d};return i>0&&(l.gap=i),this.closed&&r+d>=this.writeCursor&&(l.eof=!0),l}tail(e){let n=Math.max(0,Math.min(e,zs)),s=this.oldestAvailable,r=this.writeCursor-n,i=Math.max(s,r),o=r<s;return{bytes:this.sliceFromRing(i,this.writeCursor-i),startCursor:i,endCursor:this.writeCursor,truncated:o}}head(e){let n=Math.max(0,Math.min(e,zs)),s=this.oldestAvailable,r=s>0,i=s,o=Math.min(this.writeCursor,i+n);return{bytes:this.sliceFromRing(i,o-i),startCursor:i,endCursor:o,truncated:r}}waitForData(e,n){if(e<this.writeCursor)return Promise.resolve("data");if(this.closed)return Promise.resolve("eof");let s=Math.max(0,Math.min(n,iy));return s===0?Promise.resolve("timeout"):new Promise(r=>{let i={resolve:o=>{i.timer!==void 0&&(clearTimeout(i.timer),i.timer=void 0),r(o)},timer:setTimeout(()=>{let o=this.waiters.indexOf(i);o>=0&&this.waiters.splice(o,1),i.timer=void 0,r("timeout")},s)};this.waiters.push(i)})}grep(e){let n=this.oldestAvailable,s=e.cursor,r=s??n,i=0;s!==void 0&&s<n&&(i=n-s,r=n),r>this.writeCursor&&(r=this.writeCursor);let o=this.sliceFromRing(r,this.writeCursor-r),a=e.regex??!0,d=e.caseInsensitive===!0?"i":"",c=a?new RegExp(e.pattern,d):new RegExp(ly(e.pattern),d),l=e.invert??!1,f=Math.max(1,Math.min(e.maxMatches??oy,ay)),u=Math.max(1,Math.min(e.maxBytes??dy,cy)),p=Math.max(0,Math.min(e.contextBefore??0,iu)),g=Math.max(0,Math.min(e.contextAfter??0,iu)),h=[],w=[],v=[],b=0,x=!1,C=0,O=0,q=(N,F)=>{for(let be of v)be.remaining>0&&(be.match.after===void 0&&(be.match.after=[]),be.match.after.push({cursor:N,line:F}),be.remaining--,b+=F.length);for(;v.length>0&&v[0].remaining===0;)v.shift();if(c.test(F)!==l&&h.length<f){let be={cursor:N,line:F};if(p>0&&w.length>0){be.before=w.slice();for(let te of be.before)b+=te.line.length}b+=F.length,h.push(be),g>0&&v.push({match:be,remaining:g})}if(p>0)for(w.push({cursor:N,line:F});w.length>p;)w.shift();let J=h.length>=f&&v.length===0,ie=b>=u;return J||ie};for(let N=0;N<o.length;N++){if(o[N]!==10)continue;let F=o.subarray(C,N).toString("utf8"),U=r+C;if(C=N+1,O=C,q(U,F)){x=!0;break}}if(!x&&C<o.length&&this.closed){let N=o.subarray(C).toString("utf8"),F=r+C;q(F,N)&&(x=!0),O=o.length}let W=Math.min(r+O,this.writeCursor),Q={matches:h,truncated:x,nextCursor:W,scannedBytes:O};return i>0&&(Q.gap=i),this.closed&&W>=this.writeCursor&&(Q.eof=!0),Q}wakeWaiters(e){if(this.waiters.length===0)return;let n=this.waiters;this.waiters=[];for(let s of n)s.resolve(e)}growIfNeeded(e){if(this.currentCapacityBytes>=this.maxCapacityBytes)return;let n=this.writeCursor+e;if(n<=this.currentCapacityBytes)return;let s=this.currentCapacityBytes;for(;s<n&&s<this.maxCapacityBytes;)s=Math.min(this.maxCapacityBytes,s*2);if(s===this.currentCapacityBytes)return;let r=Buffer.alloc(s);this.storage.copy(r,0,0,this.writeCursor),this.storage=r,this.currentCapacityBytes=s}writeRing(e){let n=e.length;if(this.growIfNeeded(n),n>=this.currentCapacityBytes){let i=n-this.currentCapacityBytes;e.copy(this.storage,0,i,n);return}let s=this.writeCursor%this.currentCapacityBytes,r=this.currentCapacityBytes-s;n<=r?e.copy(this.storage,s,0,n):(e.copy(this.storage,s,0,r),e.copy(this.storage,0,r,n))}sliceFromRing(e,n){if(n<=0)return Buffer.alloc(0);let s=Buffer.alloc(n),r=e%this.currentCapacityBytes,i=Math.min(n,this.currentCapacityBytes-r);return this.storage.copy(s,0,r,r+i),i<n&&this.storage.copy(s,i,0,n-i),s}scheduleFileWrite(e){let n=this.filePath;if(n===void 0||this.fileCapReached)return;let s=this.fileCapBytes-this.fileBytesWritten;if(s<=0){this.fileCapReached=!0,this.onFileCapReached?.();return}let r=e.length<=s?e:e.subarray(0,s);this.fileBytesWritten+=r.length;let i=this.fileBytesWritten>=this.fileCapBytes;this.fileWriteChain=this.fileWriteChain.then(()=>ou.appendFile(n,r)).catch(o=>{this.logWriteError?.(o)}),i&&!this.fileCapReached&&(this.fileCapReached=!0,this.onFileCapReached?.())}async drainFileWrites(){await this.fileWriteChain.catch(()=>{})}}});var Gi,LA,du=V(()=>{"use strict";Gi=[{verb:"title",name:"hydra title",description:"Regenerate the session title + synopsis via the agent (or set title manually with an arg)"},{verb:"agent",name:"hydra agent",argsHint:"<agent>",description:"Swap the agent backing this session, preserving context"},{verb:"kill",name:"hydra kill",description:"Close this session (kills the agent; record is kept so it can be resumed later)"},{verb:"restart",name:"hydra restart",description:"Restart the agent with a fresh session/new while preserving conversation history (useful when the proxy has changed available models)"}],LA=new Map(Gi.map(t=>[t.verb,t]))});function cu(t){let e=t.lastIndexOf("/");return(e===-1?t:t.slice(e+1)).toLowerCase()}function Js(t,e){if(e.length===0)return{kind:"none",requested:t};if(e.some(r=>r.modelId===t))return{kind:"exact",modelId:t};let n=cu(t),s=e.map(r=>r.modelId).filter(r=>cu(r)===n);return s.length===1?{kind:"resolved",modelId:s[0],requested:t}:s.length>1?{kind:"ambiguous",requested:t,candidates:s}:{kind:"unknown",requested:t}}var Xi=V(()=>{"use strict"});function lu(t){if(t.length===0)return t;let e=new Map,n=new Map,s=new Map;for(let a=0;a<t.length;a++){let d=t[a];if(d===void 0)continue;let c=Ka(d);if(c?.sessionUpdate!=="tool_call_update")continue;let l=typeof c.toolCallId=="string"?c.toolCallId:void 0;if(l!==void 0&&(e.set(l,a),c.rawInput&&typeof c.rawInput=="object"&&!Array.isArray(c.rawInput)&&Object.keys(c.rawInput).length>0&&s.set(l,c.rawInput),Array.isArray(c.content)&&c.content.length>0)){let f=n.get(l);f?f.push(...c.content):n.set(l,[...c.content])}}let r=[],i=null,o=null;for(let a=0;a<t.length;a++){let d=t[a];if(d===void 0)continue;let c=Ka(d);if(!c||typeof c.sessionUpdate!="string"){r.push(d),i=null;continue}let l=c.sessionUpdate;if(l==="agent_message_chunk"||l==="agent_thought_chunk"||l==="user_message_chunk"){i&&i.kind===l?fy(r,i.outIndex,uy(c.content)):(r.push(d),i={outIndex:r.length-1,kind:l});continue}if(i=null,l==="tool_call_update"){let f=typeof c.toolCallId=="string"?c.toolCallId:void 0;if(f!==void 0&&e.get(f)!==a)continue;let u=f!==void 0&&n.has(f)?py(d,n.get(f)??[]):d;f!==void 0&&s.has(f)&&!my(u)&&(u=hy(u,s.get(f))),r.push(u);continue}if(l==="plan"){o!==null?r[o]=d:(r.push(d),o=r.length-1);continue}(l==="prompt_received"||l==="turn_complete")&&(o=null),r.push(d)}return r}function Ka(t){if(t.method!=="session/update")return;let n=t.params?.update;if(!(!n||typeof n!="object"||Array.isArray(n)))return n}function uy(t){if(!t||typeof t!="object")return"";let e=t;return typeof e.text=="string"?e.text:""}function fy(t,e,n){if(n.length===0)return;let s=t[e];if(s===void 0)return;let r=s.params??{},i=r.update??{},o=i.content??{},a=typeof o.text=="string"?o.text:"";t[e]={...s,params:{...r,update:{...i,content:{...o,text:a+n}}}}}function py(t,e){let n=t.params??{},s=n.update??{};return{...t,params:{...n,update:{...s,content:e}}}}function my(t){let n=Ka(t)?.rawInput;return!!n&&typeof n=="object"&&!Array.isArray(n)&&Object.keys(n).length>0}function hy(t,e){let n=t.params??{},s=n.update??{};return{...t,params:{...n,update:{...s,rawInput:e}}}}var uu=V(()=>{"use strict"});import*as Vt from"fs/promises";async function Dr(t,e){let n=P.queueFile(t);if(e.length===0){await Vt.unlink(n).catch(()=>{});return}await Vt.mkdir(P.sessionDir(t),{recursive:!0});let s=e.map(r=>JSON.stringify(r)).join(`
|
|
2
|
+
var tg=Object.defineProperty;var V=(t,e)=>()=>(t&&(e=t(t=0)),e);var ng=(t,e)=>{for(var n in e)tg(t,n,{get:e[n],enumerable:!0})};import*as de from"path";import*as Aa from"os";function Be(t){let e=Aa.homedir();return e?t===e?"~":t.startsWith(e+"/")?"~"+t.slice(e.length):t:t}function he(){let t=process.env[ag];if(t&&t.length>0)return de.resolve(t);if(process.env.VITEST)throw new Error("HYDRA_ACP_HOME is unset under VITEST; vitest.setup.ts must run first");return de.join(Aa.homedir(),".hydra-acp")}var ag,P,ue=V(()=>{"use strict";ag="HYDRA_ACP_HOME";P={home:he,config:()=>de.join(he(),"config.json"),authToken:()=>de.join(he(),"auth-token"),remotes:()=>de.join(he(),"remotes.json"),pidFile:()=>de.join(he(),"daemon.pid"),logFile:()=>de.join(he(),"daemon.log"),currentLogFile:()=>de.join(he(),"current.log"),registryCache:()=>de.join(he(),"registry.json"),agentsDir:()=>de.join(he(),"agents"),agentLogFile:t=>de.join(he(),"agents","logs",`${t}.log`),agentInstallDir:(t,e,n)=>de.join(he(),"agents",e,t,n),agentNpmInstallDir:(t,e,n)=>de.join(he(),"agents",e,t,n,`node${process.versions.modules}`),sessionsDir:()=>de.join(he(),"sessions"),sessionDir:t=>de.join(he(),"sessions",t),sessionFile:t=>de.join(he(),"sessions",t,"meta.json"),historyFile:t=>de.join(he(),"sessions",t,"history.jsonl"),toolsDir:t=>de.join(he(),"sessions",t,"tools"),toolBlobFile:(t,e)=>de.join(he(),"sessions",t,"tools",e),queueFile:t=>de.join(he(),"sessions",t,"queue.ndjson"),tombstonesDir:()=>de.join(he(),"sessions",".tombstones"),tombstoneAgentDir:t=>de.join(he(),"sessions",".tombstones",encodeURIComponent(t)),tombstoneFile:(t,e)=>de.join(he(),"sessions",".tombstones",encodeURIComponent(t),encodeURIComponent(e)),extensionsDir:()=>de.join(he(),"extensions"),extensionLogFile:t=>de.join(he(),"extensions",`${t}.log`),extensionPidFile:t=>de.join(he(),"extensions",`${t}.pid`),transformersDir:()=>de.join(he(),"transformers"),transformerLogFile:t=>de.join(he(),"transformers",`${t}.log`),transformerPidFile:t=>de.join(he(),"transformers",`${t}.pid`),transformerState:(t,e)=>de.join(he(),"sessions",t,"transformer-state",e),tuiHistoryFile:t=>de.join(he(),"sessions",t,"prompt-history"),globalTuiHistoryFile:()=>de.join(he(),"prompt-history"),tuiLogFile:()=>de.join(he(),"tui.log"),shimWireLogFile:()=>de.join(he(),"shim-wire.log")}});import*as Fs from"fs/promises";function Os(){let t=new Uint8Array(32);crypto.getRandomValues(t);let e="";for(let n of t)e+=n.toString(16).padStart(2,"0");return`hydra_token_${e}`}async function Ls(){try{let e=(await Fs.readFile(P.authToken(),"utf8")).trim();return e.length>0?e:void 0}catch(t){if(t.code==="ENOENT")return;throw t}}async function pe(){let t=await Ls();if(!t)throw new Error(`No service token found at ${P.authToken()}. Run \`hydra-acp init\` to create one.`);return t}async function Bs(t){await Fs.mkdir(P.home(),{recursive:!0}),await Fs.writeFile(P.authToken(),t+`
|
|
3
|
+
`,{encoding:"utf8",mode:384})}async function Or(){let t=await Ls();if(t)return t;let e=Os();return await Bs(e),process.stderr.write(`hydra-acp: initialized ${P.authToken()} with a fresh service token.
|
|
4
|
+
`),e}var mt=V(()=>{"use strict";ue()});import*as qt from"fs/promises";import*as nl from"fs";import{randomBytes as dg}from"crypto";async function ht(t,e,n={}){let r=(n.pretty??!0?JSON.stringify(e,null,2):JSON.stringify(e))+`
|
|
5
|
+
`;await cg(t,r,n)}async function cg(t,e,n={}){let s=lg(t);await qt.mkdir(s,{recursive:!0});let r=`${t}.tmp-${process.pid}-${ug()}`;try{let i={encoding:"utf8"};n.mode!==void 0&&(i.mode=n.mode),await qt.writeFile(r,e,i),await qt.rename(r,t)}catch(i){throw await qt.unlink(r).catch(()=>{}),i}if(n.mode!==void 0)try{nl.chmodSync(t,n.mode)}catch{}}async function At(t){let e;try{e=await qt.readFile(t,"utf8")}catch(n){if(n.code==="ENOENT")return;throw n}if(e.trim().length!==0)try{return JSON.parse(e)}catch{return}}function lg(t){let e=t.lastIndexOf("/");return e<=0?".":t.slice(0,e)}function ug(){return dg(4).toString("hex")}var os=V(()=>{"use strict"});import*as rl from"fs/promises";import{homedir as Ca}from"os";import{z as L}from"zod";function al(t){return t.tui.inAppSelection??t.tui.mouse}function dl(t){return Object.entries(t.extensions).map(([e,n])=>({name:e,...n}))}function cl(t){return Object.entries(t.transformers).map(([e,n])=>({name:e,...n}))}async function _i(){return await At(P.config())??{}}async function Fi(){let t=await _i(),e=t.daemon,n=e&&typeof e.authToken=="string"?e.authToken:void 0;if(!n)return;let s=!1;try{await rl.access(P.authToken()),s=!0}catch(r){if(r.code!=="ENOENT")throw r}if(s)throw new Error(`Auth token present in both ${P.authToken()} and ${P.config()} (daemon.authToken). Remove daemon.authToken from config.json to resolve.`);await Bs(n),delete e.authToken,Object.keys(e).length===0&&delete t.daemon,await ht(P.config(),t,{mode:384}),process.stderr.write(`hydra-acp: migrated auth token from ${P.config()} to ${P.authToken()}.
|
|
6
|
+
`)}async function Z(){return await Fi(),ol.parse(await _i())}async function Ds(t){await Fi();let e=await _i();t(e),ol.parse(e),await ht(P.config(),e,{mode:384})}async function Lr(t,e){await Ds(n=>{let s=n.tui&&typeof n.tui=="object"&&!Array.isArray(n.tui)?n.tui:{};s[t]=e,n.tui=s})}async function Oi(t){await Ds(e=>{e.defaultAgent=t})}async function ll(t,e){await Ds(n=>{let s=n.defaultModels&&typeof n.defaultModels=="object"?n.defaultModels:{};s[t]=e,n.defaultModels=s})}async function ul(t,e){await Ds(n=>{let s=n.agentOverrides&&typeof n.agentOverrides=="object"?n.agentOverrides:{};e===void 0?delete s[t]:s[t]={packageSpec:e},n.agentOverrides=s})}async function Ra(t,e){await Ds(n=>{let s=n.agents&&typeof n.agents=="object"?n.agents:{};e===void 0?delete s[t]:s[t]=e,n.agents=s})}async function fl(t){await Ds(e=>{let n=e.registry&&typeof e.registry=="object"?e.registry:{};n.pinned=t,e.registry=n})}async function pl(){let t=await _i();return typeof t.defaultAgent=="string"&&t.defaultAgent.length>0}function Ft(t){return t==="~"||t==="$HOME"?Ca():t.startsWith("~/")?Ca()+t.slice(1):t.startsWith("$HOME/")?Ca()+t.slice(5):t}var il,fg,Ns,pg,mg,hg,gg,yg,sl,wg,bg,ol,Ne=V(()=>{"use strict";ue();mt();os();il="https://cdn.agentclientprotocol.com/registry/v1/latest/registry.json",fg=L.object({cert:L.string(),key:L.string()}),Ns=55514,pg=L.object({host:L.string().default("127.0.0.1"),port:L.number().int().positive().default(Ns),logLevel:L.enum(["debug","info","warn","error"]).default("info"),tls:fg.optional(),sessionIdleTimeoutSeconds:L.number().int().nonnegative().default(3600),sessionHistoryMaxEntries:L.number().int().positive().default(1e4),agentStderrTailBytes:L.number().int().positive().default(4096),publicHost:L.string().optional(),agentSyncIntervalMinutes:L.number().nonnegative().default(60),sessionGcIntervalMinutes:L.number().nonnegative().default(60),sessionGcMaxAgeDays:L.number().positive().default(2)}),mg=L.object({url:L.string().url().default(il),ttlHours:L.number().positive().default(24),pinned:L.boolean().default(!1)}),hg=L.object({name:L.string().optional(),description:L.string().optional(),command:L.string().optional(),args:L.array(L.string()).optional(),env:L.record(L.string()).optional()}),gg=L.object({packageSpec:L.string().optional()}),yg=L.object({repaintThrottleMs:L.number().int().nonnegative().default(1e3),maxScrollbackLines:L.number().int().positive().default(1e4),mouse:L.boolean().default(!1),inAppSelection:L.boolean().optional(),selectionClipboard:L.enum(["primary","clipboard","both"]).default("both"),logMaxBytes:L.number().int().positive().default(5*1024*1024),cwdColumnMaxWidth:L.number().int().positive().default(32),progressIndicator:L.boolean().default(!0),defaultEnterAction:L.enum(["enqueue","amend"]).default("amend"),showThoughts:L.boolean().default(!0),ambiguousWidth:L.enum(["narrow","wide"]).default("wide"),toolContent:L.enum(["inline","references"]).default("references"),diffContextLines:L.number().int().min(0).default(3),promptHistoryMaxEntries:L.number().int().positive().default(2e3),maxToolItems:L.number().int().nonnegative().default(5),maxPlanItems:L.number().int().nonnegative().default(5),showFileUpdates:L.enum(["none","edit","diff"]).default("edit"),sessionColumns:L.array(L.enum(["session","upstream","host","state","agent","model","age","cwd","title","cost"])).nonempty().optional()}),sl=L.string().min(1).regex(/^[A-Za-z0-9._-]+$/,"extension name must be filename-safe"),wg=L.object({command:L.array(L.string()).default([]),args:L.array(L.string()).default([]),env:L.record(L.string()).default({}),enabled:L.boolean().default(!0)}),bg=L.object({command:L.array(L.string()).default([]),args:L.array(L.string()).default([]),env:L.record(L.string()).default({}),enabled:L.boolean().default(!0)}),ol=L.object({daemon:pg.default({}),registry:mg.default({url:il,ttlHours:24,pinned:!1}),agents:L.record(L.string(),hg).default({}),agentOverrides:L.record(L.string(),gg).default({}),defaultAgent:L.string().default("opencode"),defaultModels:L.record(L.string(),L.string()).default({}),synopsisAgent:L.string().optional(),synopsisModel:L.string().optional(),synopsisOnClose:L.boolean().default(!1),defaultCwd:L.string().default("~"),compressToolContent:L.boolean().default(!0),sessionListColdLimit:L.number().int().nonnegative().default(20),extensions:L.record(sl,wg).default({}),transformers:L.record(sl,bg).default({}),defaultTransformers:L.array(L.string()).default([]),npmRegistry:L.string().url().optional(),tui:yg.default({repaintThrottleMs:1e3,maxScrollbackLines:1e4,mouse:!1,logMaxBytes:5*1024*1024,cwdColumnMaxWidth:32,progressIndicator:!0,defaultEnterAction:"amend",showThoughts:!0,ambiguousWidth:"wide",toolContent:"references",diffContextLines:3,promptHistoryMaxEntries:2e3,maxToolItems:5,maxPlanItems:5,showFileUpdates:"edit",selectionClipboard:"both"})})});function on(t){return t==="127.0.0.1"||t==="::1"||t==="localhost"||t==="[::1]"}function Ta(t){return on(t)?{httpScheme:"http",wsScheme:"ws"}:{httpScheme:"https",wsScheme:"wss"}}function Ea(t){if(typeof t!="string"||t.length===0)throw new Error("expected a hydra:// URL");if(!t.startsWith("hydra://"))throw new Error(`expected hydra:// URL, got ${Li(t)}`);let e=t.slice(8);if(e.length===0||e.startsWith("/"))throw new Error(`hydra:// URL is missing a host: ${Li(t)}`);let n=e.match(/^[^/]*?:(\d+)(?:\/|$)/);if(n){let c=Number(n[1]);if(!Number.isInteger(c)||c<=0||c>65535)throw new Error(`hydra:// URL has invalid port: ${n[1]}`)}let s=vg(`http://${e}`);if(!s)throw new Error(`invalid hydra:// URL: ${Li(t)}`);let r=s.hostname;if(!r)throw new Error(`hydra:// URL is missing a host: ${Li(t)}`);let i=on(r),o;if(s.port){let c=Number(s.port);if(!Number.isInteger(c)||c<=0||c>65535)throw new Error(`hydra:// URL has invalid port: ${s.port}`);o=c}else o=i?Ns:443;let a=s.pathname.replace(/^\/+/,"");return{host:r,port:o,sessionId:a===""?void 0:a,isLoopback:i}}function ml(t){let n=on(t.host)?Ns:443,s=t.port!==void 0&&t.port!==n?`:${t.port}`:"",r=t.sessionId?`/${t.sessionId}`:"/";return`hydra://${t.host}${s}${r}`}function vg(t){try{return new URL(t)}catch{return null}}function Li(t){return t.length>80?`${t.slice(0,77)}...`:t}var Br=V(()=>{"use strict";Ne()});function Pa(t,e){return`${t}:${e}`}function hl(t,e){let n=Date.parse(t.expiresAt);return Number.isFinite(n)?n<=e:!0}function Ig(t){let e=t.lastIndexOf(":");if(e<0)return null;let n=t.slice(0,e),s=Number(t.slice(e+1));return Number.isInteger(s)?{host:n,port:s}:null}async function Sg(){let t=await At(P.remotes());return t===void 0?{version:1,entries:{}}:kg(t)}function kg(t){if(!t||typeof t!="object")return{version:1,entries:{}};let e=t,n=e.entries&&typeof e.entries=="object"?e.entries:{},s={};for(let[r,i]of Object.entries(n)){if(!i||typeof i!="object")continue;let o=i;if(typeof o.token!="string"||typeof o.expiresAt!="string")continue;let a={token:o.token,expiresAt:o.expiresAt};typeof o.label=="string"&&(a.label=o.label),s[r]=a}return{version:1,entries:s}}async function Ma(t){await ht(P.remotes(),t,{mode:384})}var Bi,gl=V(()=>{"use strict";ue();os();Bi=class t{data;constructor(e){this.data=e}static async load(){let e=await Sg(),n=Date.now(),s={},r=!1;for(let[o,a]of Object.entries(e.entries)){if(hl(a,n)){r=!0;continue}s[o]=a}let i={version:1,entries:s};return r&&await Ma(i),new t(i)}get(e,n){let s=this.data.entries[Pa(e,n)];if(s&&!hl(s,Date.now()))return s}async set(e,n,s){this.data.entries[Pa(e,n)]=s,await Ma(this.data)}async delete(e,n){let s=Pa(e,n);return s in this.data.entries?(delete this.data.entries[s],await Ma(this.data),!0):!1}list(){let e=[];for(let[n,s]of Object.entries(this.data.entries)){let r=Ig(n);r&&e.push({host:r.host,port:r.port,entry:s})}return e}}});async function Hs(t){return process.stdout.write(t),process.stdin.isTTY?new Promise((e,n)=>{let s=process.stdin,r=s.isRaw===!0,i="",o=()=>{s.removeListener("data",a),s.removeListener("error",d),r||s.setRawMode(!1),s.pause()},a=c=>{for(let l of c){if(l===10||l===13){process.stdout.write(`
|
|
7
|
+
`),o(),e(i);return}if(l===3){o(),n(new Error("password entry cancelled"));return}if(l===127||l===8){i=i.slice(0,-1);continue}i+=String.fromCharCode(l)}},d=c=>{o(),n(c)};s.setRawMode(!0),s.resume(),s.on("data",a),s.on("error",d)}):xg()}function xg(){return new Promise((t,e)=>{let n="";process.stdin.setEncoding("utf8");let s=i=>{n+=i;let o=n.indexOf(`
|
|
8
|
+
`);o!==-1&&(process.stdin.removeListener("data",s),process.stdin.removeListener("error",r),t(n.slice(0,o).replace(/\r$/,"")))},r=i=>{process.stdin.removeListener("data",s),process.stdin.removeListener("error",r),e(i)};process.stdin.on("data",s),process.stdin.on("error",r)})}var $a=V(()=>{"use strict"});import*as yl from"path";function Pn(){let t=process.argv[1];if(!t)return"hydra-acp";let e=yl.basename(t);return e==="cli.js"||e==="cli"?"hydra-acp":e}var Ni=V(()=>{"use strict"});import*as bl from"os";async function Wt(t){let e=await Or(),n=t.daemon.host,s=t.daemon.port,r=!!t.daemon.tls,i=r?"https":"http",o=r?"wss":"ws";return{baseUrl:`${i}://${n}:${s}`,wsUrl:`${o}://${n}:${s}/acp`,token:e,display:`${n}:${s}`,isLocal:on(n)}}function _a(t,e){let{httpScheme:n,wsScheme:s}=Ta(t.host);return{baseUrl:`${n}://${t.host}:${t.port}`,wsUrl:`${s}://${t.host}:${t.port}/acp`,token:e,display:Il(t),isLocal:t.isLoopback}}async function vl(t,e={}){let n=e.fetchImpl??fetch,s=e.promptImpl??Hs,r=e.preferServiceToken??!0,i=e.allowPrompt??!0;if(t.isLoopback&&r){let g=await Ls();if(g)return _a(t,g)}let o=e.store??await Bi.load(),a=o.get(t.host,t.port);if(a)return _a(t,a.token);if(!i)throw new Fa(t.host,t.port);let d=Il(t),c=await s(`Password for ${d}: `);if(c.length===0)throw new Error("Password is required to attach to a remote daemon.");let{httpScheme:l}=Ta(t.host),f=`${l}://${t.host}:${t.port}`,u=await n(`${f}/v1/auth/login`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({password:c,label:wl()})});if(u.status===401)throw new Error(`Wrong password for ${d}.`);if(u.status===403)throw new Error(`No password is configured on ${d}. Run \`hydra-acp auth password\` on the daemon host first.`);if(u.status===429)throw new Error(`Too many failed login attempts on ${d}; try again later.`);if(!u.ok)throw new Error(`Login to ${d} failed: HTTP ${u.status}`);let p=await u.json();if(!p.session_token||!p.expires_at)throw new Error(`Login to ${d} returned a malformed response.`);return await o.set(t.host,t.port,{token:p.session_token,expiresAt:p.expires_at,label:wl()}),_a(t,p.session_token)}function wl(){try{let t=bl.hostname();return t.length>0?t:"remote"}catch{return"remote"}}function Il(t){let e=t.isLoopback?Ns:443;return t.port===e?t.host:`${t.host}:${t.port}`}var Fa,Us=V(()=>{"use strict";Ne();mt();Br();gl();$a();Ni();Br();Fa=class extends Error{host;port;constructor(e,n){let s=n===443?"":`:${n}`;super(`No cached credentials for ${e}:${n}. Run \`${Pn()} --session hydra://${e}${s}/\` once in a terminal to log in.`),this.name="NoCachedCredentialError",this.host=e,this.port=n}}});import{z as A}from"zod";function wt(t){if(!t)return{};let e=t[Ct];if(!e||typeof e!="object"||Array.isArray(e))return{};let n=e,s={};if(typeof n.upstreamSessionId=="string"&&(s.upstreamSessionId=n.upstreamSessionId),typeof n.agentId=="string"&&(s.agentId=n.agentId),typeof n.cwd=="string"&&(s.cwd=n.cwd),typeof n.clientId=="string"&&(s.clientId=n.clientId),typeof n.readonly=="boolean"&&(s.readonly=n.readonly),(n.replayMode==="instant"||n.replayMode==="drip")&&(s.replayMode=n.replayMode),typeof n.dripSpeed=="number"&&n.dripSpeed>0&&(s.dripSpeed=n.dripSpeed),(n.toolContent==="inline"||n.toolContent==="references")&&(s.toolContent=n.toolContent),n.detachStatus==="detached"&&(s.detachStatus=n.detachStatus),typeof n.title=="string"&&(s.title=n.title),Array.isArray(n.agentArgs)&&n.agentArgs.every(r=>typeof r=="string")&&(s.agentArgs=n.agentArgs),Array.isArray(n.transformers)&&n.transformers.every(r=>typeof r=="string")&&(s.transformers=n.transformers),n.resume){let r=Gg.safeParse(n.resume);r.success&&(s.resume=r.data)}if(typeof n.model=="string"&&(s.model=n.model),typeof n.currentModel=="string"&&(s.currentModel=n.currentModel),typeof n.currentMode=="string"&&(s.currentMode=n.currentMode),n.currentUsage){let r=Ql.safeParse(n.currentUsage);r.success&&(s.currentUsage=r.data)}if(typeof n.turnStartedAt=="number"&&n.turnStartedAt>0&&(s.turnStartedAt=n.turnStartedAt),Array.isArray(n.availableCommands)){let r=[];for(let i of n.availableCommands){if(!i||typeof i!="object"||Array.isArray(i))continue;let o=i;if(typeof o.name!="string")continue;let a={name:o.name};typeof o.description=="string"&&(a.description=o.description),r.push(a)}r.length>0&&(s.availableCommands=r)}if(n.prompt&&typeof n.prompt=="object"&&!Array.isArray(n.prompt)){let r=n.prompt,i={};typeof r.queueing=="boolean"&&(i.queueing=r.queueing),typeof r.cancelling=="boolean"&&(i.cancelling=r.cancelling),typeof r.updating=="boolean"&&(i.updating=r.updating),typeof r.amending=="boolean"&&(i.amending=r.amending),typeof r.pipelining=="boolean"&&(i.pipelining=r.pipelining),s.prompt=i}if(n.agents&&typeof n.agents=="object"&&!Array.isArray(n.agents)){let r=n.agents,i={};typeof r.list=="boolean"&&(i.list=r.list),typeof r.installProgress=="boolean"&&(i.installProgress=r.installProgress),s.agents=i}if(typeof n.mcpStdin=="boolean"&&(s.mcpStdin=n.mcpStdin),typeof n.interactive=="boolean"&&(s.interactive=n.interactive),typeof n.ancillary=="boolean"&&(s.ancillary=n.ancillary),Array.isArray(n.queue)){let r=[];for(let i of n.queue){if(!i||typeof i!="object"||Array.isArray(i))continue;let o=i,a=o.originator;if(typeof o.messageId!="string"||!a||typeof a.clientId!="string"||!Array.isArray(o.prompt)||typeof o.position!="number"||typeof o.enqueuedAt!="number")continue;let d={clientId:a.clientId};typeof a.name=="string"&&(d.name=a.name),typeof a.version=="string"&&(d.version=a.version),r.push({messageId:o.messageId,originator:d,prompt:o.prompt,position:o.position,enqueuedAt:o.enqueuedAt})}r.length>0&&(s.queue=r)}if(Array.isArray(n.availableModes)){let r=[];for(let i of n.availableModes){if(!i||typeof i!="object"||Array.isArray(i))continue;let o=i;if(typeof o.id!="string")continue;let a={id:o.id};typeof o.name=="string"&&(a.name=o.name),typeof o.description=="string"&&(a.description=o.description),r.push(a)}r.length>0&&(s.availableModes=r)}if(Array.isArray(n.availableModels)){let r=[];for(let i of n.availableModels){if(!i||typeof i!="object"||Array.isArray(i))continue;let o=i;if(typeof o.modelId!="string")continue;let a={modelId:o.modelId};typeof o.name=="string"&&(a.name=o.name),typeof o.description=="string"&&(a.description=o.description),r.push(a)}r.length>0&&(s.availableModels=r)}if((n.status==="live"||n.status==="cold")&&(s.status=n.status),typeof n.busy=="boolean"&&(s.busy=n.busy),typeof n.awaitingInput=="boolean"&&(s.awaitingInput=n.awaitingInput),typeof n.attachedClients=="number"&&(s.attachedClients=n.attachedClients),typeof n.importedFromMachine=="string"&&(s.importedFromMachine=n.importedFromMachine),typeof n.importedFromUpstreamSessionId=="string"&&(s.importedFromUpstreamSessionId=n.importedFromUpstreamSessionId),typeof n.parentSessionId=="string"&&(s.parentSessionId=n.parentSessionId),typeof n.forkedFromSessionId=="string"&&(s.forkedFromSessionId=n.forkedFromSessionId),typeof n.forkedFromMessageId=="string"&&(s.forkedFromMessageId=n.forkedFromMessageId),n.originatingClient&&typeof n.originatingClient=="object"&&!Array.isArray(n.originatingClient)&&typeof n.originatingClient.name=="string"){let r=n.originatingClient;s.originatingClient={name:r.name,...typeof r.version=="string"?{version:r.version}:{}}}return n.agentCapabilities!==void 0&&(s.agentCapabilities=n.agentCapabilities),s}function Wi(t,e){return{...t??{},[Ct]:e}}function zi(t,e){let n={attachedClients:t.attachedClients,status:t.status,busy:t.busy,awaitingInput:t.awaitingInput};return t.cwd!==void 0&&(n.cwd=t.cwd),t.title!==void 0&&(n.title=t.title),t.agentId!==void 0&&(n.agentId=t.agentId),t.upstreamSessionId!==void 0&&(n.upstreamSessionId=t.upstreamSessionId),t.currentModel!==void 0&&(n.currentModel=t.currentModel),t.currentUsage!==void 0&&(n.currentUsage=t.currentUsage),t.importedFromMachine!==void 0&&(n.importedFromMachine=t.importedFromMachine),t.importedFromUpstreamSessionId!==void 0&&(n.importedFromUpstreamSessionId=t.importedFromUpstreamSessionId),t.parentSessionId!==void 0&&(n.parentSessionId=t.parentSessionId),t.forkedFromSessionId!==void 0&&(n.forkedFromSessionId=t.forkedFromSessionId),t.forkedFromMessageId!==void 0&&(n.forkedFromMessageId=t.forkedFromMessageId),t.originatingClient!==void 0&&(n.originatingClient=t.originatingClient),t.interactive!==void 0&&(n.interactive=t.interactive),t.priority!==void 0&&t.priority>0&&(n.priority=t.priority),e&&(e.clientId!==void 0&&(n.clientId=e.clientId),e.currentMode!==void 0&&(n.currentMode=e.currentMode),e.agentArgs!==void 0&&e.agentArgs.length>0&&(n.agentArgs=e.agentArgs),e.availableCommands!==void 0&&e.availableCommands.length>0&&(n.availableCommands=e.availableCommands),e.availableModes!==void 0&&e.availableModes.length>0&&(n.availableModes=e.availableModes),e.availableModels!==void 0&&e.availableModels.length>0&&(n.availableModels=e.availableModels),e.turnStartedAt!==void 0&&(n.turnStartedAt=e.turnStartedAt),e.agentCapabilities!==void 0&&(n.agentCapabilities=e.agentCapabilities),e.queue!==void 0&&e.queue.length>0&&(n.queue=e.queue)),n}function Gl(t){let e={sessionId:t.sessionId,cwd:t.cwd,updatedAt:t.updatedAt,_meta:Wi(t._meta,zi(t))};return t.title!==void 0&&(e.title=t.title),e}var yt,B,zl,Qg,Jl,Gg,Kl,Ct,Vl,Yl,Ql,gA,Xg,yA,Xl,Ji,Zl,wA,bA,vA,eu,IA,tu,SA,nu,kA,xA,su,Ki,dt=V(()=>{"use strict";yt=1,B={ParseError:-32700,InvalidRequest:-32600,MethodNotFound:-32601,InvalidParams:-32602,InternalError:-32603,SessionNotFound:-32001,NotAuthorisedToAttach:-32002,MultiClientNotSupported:-32003,AgentNotInstalled:-32005,BundleAlreadyImported:-32010,PermissionDenied:-32011,AlreadyAttached:-32012,StreamNotEnabled:-32013,SessionClosing:-32014},zl=A.object({protocolVersion:A.number().optional(),clientCapabilities:A.record(A.unknown()).optional(),clientInfo:A.object({name:A.string(),version:A.string().optional()}).optional()}),Qg=A.enum(["full","pending_only","none","after_message"]),Jl=A.object({cwd:A.string(),mcpServers:A.array(A.unknown()).optional(),_meta:A.record(A.unknown()).optional()}),Gg=A.object({upstreamSessionId:A.string(),agentId:A.string(),cwd:A.string(),title:A.string().optional(),agentArgs:A.array(A.string()).optional()}),Kl=A.object({sessionId:A.string(),historyPolicy:Qg.default("full"),afterMessageId:A.string().optional(),clientId:A.string().optional(),clientInfo:A.object({name:A.string(),version:A.string().optional()}).optional(),_meta:A.record(A.unknown()).optional()}),Ct="hydra-acp";Vl=A.object({sessionId:A.string()}),Yl=A.object({cwd:A.string().optional(),cursor:A.string().optional()}),Ql=A.object({used:A.number().optional(),size:A.number().optional(),costAmount:A.number().optional(),costCurrency:A.string().optional()}),gA=A.object({sessionId:A.string(),upstreamSessionId:A.string().optional(),cwd:A.string(),title:A.string().optional(),agentId:A.string().optional(),currentModel:A.string().optional(),currentUsage:Ql.optional(),importedFromMachine:A.string().optional(),importedFromUpstreamSessionId:A.string().optional(),parentSessionId:A.string().optional(),forkedFromSessionId:A.string().optional(),forkedFromMessageId:A.string().optional(),originatingClient:A.object({name:A.string(),version:A.string().optional()}).optional(),interactive:A.boolean().optional(),priority:A.number().int().nonnegative().optional(),updatedAt:A.string(),attachedClients:A.number().int().nonnegative(),status:A.enum(["live","cold"]).default("live"),busy:A.boolean().default(!1),awaitingInput:A.boolean().default(!1),_meta:A.record(A.unknown()).optional()}),Xg=A.object({sessionId:A.string(),cwd:A.string(),title:A.string().optional(),updatedAt:A.string().optional(),_meta:A.record(A.unknown()).optional()}),yA=A.object({sessions:A.array(Xg),nextCursor:A.string().optional()});Xl=A.object({sessionId:A.string(),prompt:A.array(A.unknown()),_meta:A.record(A.unknown()).optional()}),Ji=A.object({sessionId:A.string()}),Zl=A.object({clientId:A.string(),name:A.string().optional(),version:A.string().optional()}),wA=A.object({sessionId:A.string(),messageId:A.string(),originator:Zl,prompt:A.array(A.unknown()),position:A.number().int().nonnegative(),queueDepth:A.number().int().positive(),enqueuedAt:A.number()}),bA=A.object({sessionId:A.string(),messageId:A.string(),prompt:A.array(A.unknown())}),vA=A.object({sessionId:A.string(),messageId:A.string(),reason:A.enum(["started","cancelled","abandoned"])}),eu=A.object({sessionId:A.string(),messageId:A.string()}),IA=A.object({cancelled:A.boolean(),reason:A.enum(["ok","not_found","already_running"])}),tu=A.object({sessionId:A.string(),messageId:A.string(),prompt:A.array(A.unknown())}),SA=A.object({updated:A.boolean(),reason:A.enum(["ok","not_found","already_running"])}),nu=A.object({sessionId:A.string(),targetMessageId:A.string(),prompt:A.array(A.unknown()),replaceQueue:A.boolean().optional(),onTargetCompleted:A.enum(["reject","send_anyway"]).optional()}),kA=A.object({amended:A.boolean(),reason:A.enum(["ok","target_completed","target_cancelled","target_not_found"]),messageId:A.string().optional()}),xA=A.object({sessionId:A.string(),cancelledMessageId:A.string(),newMessageId:A.string(),prompt:A.array(A.unknown()),originator:Zl,amendedAt:A.number()}),su=A.object({agentId:A.string(),version:A.string(),source:A.enum(["binary","npm"]),phase:A.enum(["download_start","download_progress","download_done","extract","install_start","installed"]),receivedBytes:A.number().optional(),totalBytes:A.number().optional(),packageSpec:A.string().optional()}),Ki="hydra-acp/agents/install_progress"});import{nanoid as Zg}from"nanoid";var Kt,Nr=V(()=>{"use strict";dt();Kt=class t{constructor(e){this.stream=e;this.stream.onMessage(n=>this.handleIncoming(n)),this.stream.onClose(n=>this.handleClose(n))}stream;requestHandlers=new Map;defaultRequestHandler;notificationHandlers=new Map;bufferedNotifications=new Map;static MAX_BUFFERED_PER_METHOD=64;pending=new Map;closed=!1;closeHandlers=[];orphanErrorHandlers=[];onRequest(e,n){this.requestHandlers.set(e,n)}setDefaultHandler(e){this.defaultRequestHandler=e}onNotification(e,n){this.notificationHandlers.set(e,n);let s=this.bufferedNotifications.get(e);if(s){this.bufferedNotifications.delete(e);for(let r of s)try{n(r.params,r.method)}catch{}}}drainBuffered(e){let s=this.bufferedNotifications.get(e)?.length??0;return this.bufferedNotifications.delete(e),s}onClose(e){this.closeHandlers.push(e)}onOrphanError(e){this.orphanErrorHandlers.push(e)}async request(e,n){return this.requestWithId(e,n).response}requestWithId(e,n){if(this.closed)return{id:"",response:Promise.reject(new Error("connection is closed"))};let s=Zg(),r={jsonrpc:"2.0",id:s,method:e,params:n},i=new Promise((o,a)=>{this.pending.set(s,{resolve:d=>o(d),reject:a}),this.stream.send(r).catch(d=>{this.pending.delete(s),a(d)})});return{id:s,response:i}}notify(e,n){if(this.closed)return Promise.resolve();let s={jsonrpc:"2.0",method:e,params:n};return this.stream.send(s)}async close(){this.closed||await this.stream.close()}fail(e){this.handleClose(e)}handleIncoming(e){"method"in e?"id"in e&&e.id!==void 0?this.handleRequest(e).catch(()=>{}):this.handleNotification(e):"id"in e?this.handleResponse(e):"error"in e&&this.handleResponse(e)}async handleRequest(e){let n=this.requestHandlers.get(e.method)??this.defaultRequestHandler;if(!n){await this.sendError(e.id,{code:B.MethodNotFound,message:`Method not found: ${e.method}`}).catch(()=>{});return}try{let s=await n(e.params,e.method),r={jsonrpc:"2.0",id:e.id,result:s};await this.stream.send(r).catch(()=>{})}catch(s){let r=s;await this.sendError(e.id,{code:r.code??B.InternalError,message:r.message,data:r.data}).catch(()=>{})}}handleNotification(e){let n=this.notificationHandlers.get(e.method);if(n){n(e.params,e.method);return}let s=this.bufferedNotifications.get(e.method);s||(s=[],this.bufferedNotifications.set(e.method,s)),s.push(e),s.length>t.MAX_BUFFERED_PER_METHOD&&s.shift()}handleResponse(e){let n=this.pending.get(e.id);if(!n){if(e.error)for(let s of this.orphanErrorHandlers)try{s({code:e.error.code,message:e.error.message,data:e.error.data})}catch{}return}if(this.pending.delete(e.id),e.error){let s=new Error(e.error.message);s.code=e.error.code,s.data=e.error.data,n.reject(s)}else n.resolve(e.result)}async sendError(e,n){let s={jsonrpc:"2.0",id:e,error:n};await this.stream.send(s)}handleClose(e){if(!this.closed){this.closed=!0;for(let n of this.pending.values())n.reject(e??new Error("connection closed"));this.pending.clear();for(let n of this.closeHandlers)n(e)}}}});import*as ou from"fs/promises";function uy(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}var ry,iy,Js,oy,ay,dy,cy,ly,iu,Qi,au=V(()=>{"use strict";ry=64*1024*1024,iy=1*1024*1024,Js=64*1024,oy=6e4,ay=100,dy=1e3,cy=64*1024,ly=256*1024,iu=20;Qi=class{storage;maxCapacityBytes;currentCapacityBytes;writeCursor=0;closed=!1;waiters=[];filePath;fileCapBytes;fileBytesWritten=0;fileCapReached=!1;onFileCapReached;logWriteError;fileWriteChain=Promise.resolve();constructor(e={}){if(this.maxCapacityBytes=e.capacityBytes??ry,this.maxCapacityBytes<=0)throw new Error("capacityBytes must be > 0");this.currentCapacityBytes=Math.min(iy,this.maxCapacityBytes),this.storage=Buffer.alloc(this.currentCapacityBytes),this.filePath=e.filePath,this.fileCapBytes=e.fileCapBytes??Number.POSITIVE_INFINITY,this.onFileCapReached=e.onFileCapReached,this.logWriteError=e.logWriteError}get capacity(){return this.maxCapacityBytes}get allocatedBytes(){return this.currentCapacityBytes}get writeCursorPos(){return this.writeCursor}get oldestAvailable(){return Math.max(0,this.writeCursor-this.currentCapacityBytes)}get isClosed(){return this.closed}append(e){this.closed||e.length===0||(this.writeRing(e),this.writeCursor+=e.length,this.filePath!==void 0&&this.scheduleFileWrite(e),this.wakeWaiters("data"))}close(){this.closed||(this.closed=!0,this.wakeWaiters("eof"))}read(e,n){let s=Math.max(0,Math.min(n,Js));if(s===0){let f={bytes:Buffer.alloc(0),nextCursor:e};return this.closed&&e>=this.writeCursor&&(f.eof=!0),f}let r=e,i=0,o=this.oldestAvailable;r<o&&(i=o-r,r=o);let a=this.writeCursor-r;if(a<=0){let f={bytes:Buffer.alloc(0),nextCursor:r};return i>0&&(f.gap=i),this.closed&&(f.eof=!0),f}let d=Math.min(a,s),l={bytes:this.sliceFromRing(r,d),nextCursor:r+d};return i>0&&(l.gap=i),this.closed&&r+d>=this.writeCursor&&(l.eof=!0),l}tail(e){let n=Math.max(0,Math.min(e,Js)),s=this.oldestAvailable,r=this.writeCursor-n,i=Math.max(s,r),o=r<s;return{bytes:this.sliceFromRing(i,this.writeCursor-i),startCursor:i,endCursor:this.writeCursor,truncated:o}}head(e){let n=Math.max(0,Math.min(e,Js)),s=this.oldestAvailable,r=s>0,i=s,o=Math.min(this.writeCursor,i+n);return{bytes:this.sliceFromRing(i,o-i),startCursor:i,endCursor:o,truncated:r}}waitForData(e,n){if(e<this.writeCursor)return Promise.resolve("data");if(this.closed)return Promise.resolve("eof");let s=Math.max(0,Math.min(n,oy));return s===0?Promise.resolve("timeout"):new Promise(r=>{let i={resolve:o=>{i.timer!==void 0&&(clearTimeout(i.timer),i.timer=void 0),r(o)},timer:setTimeout(()=>{let o=this.waiters.indexOf(i);o>=0&&this.waiters.splice(o,1),i.timer=void 0,r("timeout")},s)};this.waiters.push(i)})}grep(e){let n=this.oldestAvailable,s=e.cursor,r=s??n,i=0;s!==void 0&&s<n&&(i=n-s,r=n),r>this.writeCursor&&(r=this.writeCursor);let o=this.sliceFromRing(r,this.writeCursor-r),a=e.regex??!0,d=e.caseInsensitive===!0?"i":"",c=a?new RegExp(e.pattern,d):new RegExp(uy(e.pattern),d),l=e.invert??!1,f=Math.max(1,Math.min(e.maxMatches??ay,dy)),u=Math.max(1,Math.min(e.maxBytes??cy,ly)),p=Math.max(0,Math.min(e.contextBefore??0,iu)),g=Math.max(0,Math.min(e.contextAfter??0,iu)),h=[],w=[],v=[],b=0,x=!1,C=0,O=0,q=(N,F)=>{for(let be of v)be.remaining>0&&(be.match.after===void 0&&(be.match.after=[]),be.match.after.push({cursor:N,line:F}),be.remaining--,b+=F.length);for(;v.length>0&&v[0].remaining===0;)v.shift();if(c.test(F)!==l&&h.length<f){let be={cursor:N,line:F};if(p>0&&w.length>0){be.before=w.slice();for(let te of be.before)b+=te.line.length}b+=F.length,h.push(be),g>0&&v.push({match:be,remaining:g})}if(p>0)for(w.push({cursor:N,line:F});w.length>p;)w.shift();let J=h.length>=f&&v.length===0,ie=b>=u;return J||ie};for(let N=0;N<o.length;N++){if(o[N]!==10)continue;let F=o.subarray(C,N).toString("utf8"),U=r+C;if(C=N+1,O=C,q(U,F)){x=!0;break}}if(!x&&C<o.length&&this.closed){let N=o.subarray(C).toString("utf8"),F=r+C;q(F,N)&&(x=!0),O=o.length}let W=Math.min(r+O,this.writeCursor),Q={matches:h,truncated:x,nextCursor:W,scannedBytes:O};return i>0&&(Q.gap=i),this.closed&&W>=this.writeCursor&&(Q.eof=!0),Q}wakeWaiters(e){if(this.waiters.length===0)return;let n=this.waiters;this.waiters=[];for(let s of n)s.resolve(e)}growIfNeeded(e){if(this.currentCapacityBytes>=this.maxCapacityBytes)return;let n=this.writeCursor+e;if(n<=this.currentCapacityBytes)return;let s=this.currentCapacityBytes;for(;s<n&&s<this.maxCapacityBytes;)s=Math.min(this.maxCapacityBytes,s*2);if(s===this.currentCapacityBytes)return;let r=Buffer.alloc(s);this.storage.copy(r,0,0,this.writeCursor),this.storage=r,this.currentCapacityBytes=s}writeRing(e){let n=e.length;if(this.growIfNeeded(n),n>=this.currentCapacityBytes){let i=n-this.currentCapacityBytes;e.copy(this.storage,0,i,n);return}let s=this.writeCursor%this.currentCapacityBytes,r=this.currentCapacityBytes-s;n<=r?e.copy(this.storage,s,0,n):(e.copy(this.storage,s,0,r),e.copy(this.storage,0,r,n))}sliceFromRing(e,n){if(n<=0)return Buffer.alloc(0);let s=Buffer.alloc(n),r=e%this.currentCapacityBytes,i=Math.min(n,this.currentCapacityBytes-r);return this.storage.copy(s,0,r,r+i),i<n&&this.storage.copy(s,i,0,n-i),s}scheduleFileWrite(e){let n=this.filePath;if(n===void 0||this.fileCapReached)return;let s=this.fileCapBytes-this.fileBytesWritten;if(s<=0){this.fileCapReached=!0,this.onFileCapReached?.();return}let r=e.length<=s?e:e.subarray(0,s);this.fileBytesWritten+=r.length;let i=this.fileBytesWritten>=this.fileCapBytes;this.fileWriteChain=this.fileWriteChain.then(()=>ou.appendFile(n,r)).catch(o=>{this.logWriteError?.(o)}),i&&!this.fileCapReached&&(this.fileCapReached=!0,this.onFileCapReached?.())}async drainFileWrites(){await this.fileWriteChain.catch(()=>{})}}});var Gi,BA,du=V(()=>{"use strict";Gi=[{verb:"title",name:"hydra title",description:"Regenerate the session title + synopsis via the agent (or set title manually with an arg)"},{verb:"agent",name:"hydra agent",argsHint:"<agent>",description:"Swap the agent backing this session, preserving context"},{verb:"kill",name:"hydra kill",description:"Close this session (kills the agent; record is kept so it can be resumed later)"},{verb:"restart",name:"hydra restart",description:"Restart the agent with a fresh session/new while preserving conversation history (useful when the proxy has changed available models)"},{verb:"config",name:"hydra config",argsHint:"[<id> [<value>]]",description:"List or set an agent-advertised configOption (model, mode, effort, etc.). With no args, lists all options; with <id>, shows its choices; with <id> <value>, applies it."}],BA=new Map(Gi.map(t=>[t.verb,t]))});function cu(t){let e=t.lastIndexOf("/");return(e===-1?t:t.slice(e+1)).toLowerCase()}function Ks(t,e){if(e.length===0)return{kind:"none",requested:t};if(e.some(r=>r.modelId===t))return{kind:"exact",modelId:t};let n=cu(t),s=e.map(r=>r.modelId).filter(r=>cu(r)===n);return s.length===1?{kind:"resolved",modelId:s[0],requested:t}:s.length>1?{kind:"ambiguous",requested:t,candidates:s}:{kind:"unknown",requested:t}}var Xi=V(()=>{"use strict"});function lu(t){if(t.length===0)return t;let e=new Map,n=new Map,s=new Map;for(let a=0;a<t.length;a++){let d=t[a];if(d===void 0)continue;let c=Ka(d);if(c?.sessionUpdate!=="tool_call_update")continue;let l=typeof c.toolCallId=="string"?c.toolCallId:void 0;if(l!==void 0&&(e.set(l,a),c.rawInput&&typeof c.rawInput=="object"&&!Array.isArray(c.rawInput)&&Object.keys(c.rawInput).length>0&&s.set(l,c.rawInput),Array.isArray(c.content)&&c.content.length>0)){let f=n.get(l);f?f.push(...c.content):n.set(l,[...c.content])}}let r=[],i=null,o=null;for(let a=0;a<t.length;a++){let d=t[a];if(d===void 0)continue;let c=Ka(d);if(!c||typeof c.sessionUpdate!="string"){r.push(d),i=null;continue}let l=c.sessionUpdate;if(l==="agent_message_chunk"||l==="agent_thought_chunk"||l==="user_message_chunk"){i&&i.kind===l?py(r,i.outIndex,fy(c.content)):(r.push(d),i={outIndex:r.length-1,kind:l});continue}if(i=null,l==="tool_call_update"){let f=typeof c.toolCallId=="string"?c.toolCallId:void 0;if(f!==void 0&&e.get(f)!==a)continue;let u=f!==void 0&&n.has(f)?my(d,n.get(f)??[]):d;f!==void 0&&s.has(f)&&!hy(u)&&(u=gy(u,s.get(f))),r.push(u);continue}if(l==="plan"){o!==null?r[o]=d:(r.push(d),o=r.length-1);continue}(l==="prompt_received"||l==="turn_complete")&&(o=null),r.push(d)}return r}function Ka(t){if(t.method!=="session/update")return;let n=t.params?.update;if(!(!n||typeof n!="object"||Array.isArray(n)))return n}function fy(t){if(!t||typeof t!="object")return"";let e=t;return typeof e.text=="string"?e.text:""}function py(t,e,n){if(n.length===0)return;let s=t[e];if(s===void 0)return;let r=s.params??{},i=r.update??{},o=i.content??{},a=typeof o.text=="string"?o.text:"";t[e]={...s,params:{...r,update:{...i,content:{...o,text:a+n}}}}}function my(t,e){let n=t.params??{},s=n.update??{};return{...t,params:{...n,update:{...s,content:e}}}}function hy(t){let n=Ka(t)?.rawInput;return!!n&&typeof n=="object"&&!Array.isArray(n)&&Object.keys(n).length>0}function gy(t,e){let n=t.params??{},s=n.update??{};return{...t,params:{...n,update:{...s,rawInput:e}}}}var uu=V(()=>{"use strict"});import*as Vt from"fs/promises";async function Dr(t,e){let n=P.queueFile(t);if(e.length===0){await Vt.unlink(n).catch(()=>{});return}await Vt.mkdir(P.sessionDir(t),{recursive:!0});let s=e.map(r=>JSON.stringify(r)).join(`
|
|
9
9
|
`)+`
|
|
10
10
|
`;await Vt.writeFile(n,s,"utf8")}async function fu(t){let e=P.queueFile(t),n;try{n=await Vt.readFile(e,"utf8")}catch(r){if(r.code==="ENOENT")return[];throw r}let s=[];for(let r of n.split(`
|
|
11
|
-
`))if(r.trim())try{let i=JSON.parse(r);i&&typeof i.messageId=="string"&&Array.isArray(i.prompt)&&typeof i.enqueuedAt=="number"&&s.push(i)}catch{}return s}async function pu(t){let e=P.queueFile(t);await Vt.unlink(e).catch(()=>{})}var Va=V(()=>{"use strict";ue()});import{customAlphabet as hu}from"nanoid";import*as wu from"fs/promises";function Ks(){return`m_${yu()}`}function He(t){return t.startsWith(an)?t.slice(an.length):t}function bt(t,e){return t.code=e,t}function by(t,e){if(t!=="session/update")return!1;let s=(e??{}).update?.sessionUpdate;return typeof s=="string"&&wy.has(s)}function vy(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++)if(t[n]?.name!==e[n]?.name||t[n]?.description!==e[n]?.description)return!1;return!0}function Iy(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++)if(t[n]?.id!==e[n]?.id||t[n]?.name!==e[n]?.name||t[n]?.description!==e[n]?.description)return!1;return!0}function Sy(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++)if(t[n]?.modelId!==e[n]?.modelId||t[n]?.name!==e[n]?.name||t[n]?.description!==e[n]?.description)return!1;return!0}function as(t){if(!Array.isArray(t))return[];let e=[];for(let n of t){if(!n||typeof n!="object"||Array.isArray(n))continue;let s=n,r=typeof s.modelId=="string"&&s.modelId.trim()||typeof s.value=="string"&&s.value.trim()||typeof s.id=="string"&&s.id.trim()||void 0;if(!r)continue;let i={modelId:r};typeof s.name=="string"&&s.name.length>0&&(i.name=s.name),typeof s.description=="string"&&s.description.length>0&&(i.description=s.description),e.push(i)}return e}function Qs(t){if(!Array.isArray(t))return[];let e=[];for(let n of t){if(!n||typeof n!="object"||Array.isArray(n))continue;let s=n,r=typeof s.value=="string"&&s.value.trim()||typeof s.id=="string"&&s.id.trim()||void 0;if(!r)continue;let i={id:r};typeof s.name=="string"&&s.name.length>0&&(i.name=s.name),typeof s.description=="string"&&s.description.length>0&&(i.description=s.description),e.push(i)}return e}function ky(t){let n=(t??{}).update??{};if(n.sessionUpdate!=="available_modes_update")return null;let s=n.availableModes;if(!Array.isArray(s))return[];let r=[];for(let i of s){if(!i||typeof i!="object")continue;let o=i;if(typeof o.id!="string"||o.id.length===0)continue;let a={id:o.id};typeof o.name=="string"&&(a.name=o.name),typeof o.description=="string"&&(a.description=o.description),r.push(a)}return r}function xy(t,e){let s=(e??{}).update??{};if(s.sessionUpdate!=="agent_message_chunk")return;let r=s.content??{};typeof r.text=="string"&&t.chunks.push(r.text)}function Ay(t){let n=(t??{}).update??{};if(n.sessionUpdate!=="available_commands_update")return null;let s=n.availableCommands??n.commands;if(!Array.isArray(s))return[];let r=[];for(let i of s){if(!i||typeof i!="object")continue;let o=i;if(typeof o.name!="string"||o.name.length===0)continue;let a={name:o.name};typeof o.description=="string"&&(a.description=o.description),r.push(a)}return r}function Cy(t,e){if(t!=="session/update"||!e||typeof e!="object")return e;let n=e;return!n.update||typeof n.update!="object"||Array.isArray(n.update)||typeof n.update.messageId=="string"?e:{...e,update:{...n.update,messageId:Ks()}}}function Ga(t,e){for(let n=0;n<t.length;n++){let s=t[n];if(!s||s.method!=="session/update")continue;if(s.params?.update?.messageId===e)return n}return-1}function Ry(t){if(!t||typeof t!="object")return;let e=t.toolCall;if(!e||typeof e!="object")return;let n=e.toolCallId;return typeof n=="string"?n:void 0}function Ty(t){let e=Ey(t.result),n={sessionUpdate:"permission_resolved"};return t.toolCallId!==void 0&&(n.toolCallId=t.toolCallId),e&&(n.outcome=e,e.kind==="selected"&&typeof e.optionId=="string"&&(n.chosenOptionId=e.optionId)),n.resolvedBy=Py(t.resolver),n}function Ey(t){if(!t||typeof t!="object")return;let e=t.outcome;if(!e||typeof e!="object")return;let n=e.kind;if(typeof n!="string")return;let s={kind:n},r=e.optionId;typeof r=="string"&&(s.optionId=r);let i=e.reason;return typeof i=="string"&&(s.reason=i),s}function Py(t){let e={clientId:t.clientId};return t.clientInfo?.name&&(e.name=t.clientInfo.name),t.clientInfo?.version&&(e.version=t.clientInfo.version),e}function Vs(t){return typeof t=="string"?t:Array.isArray(t)?t.map(e=>e&&typeof e=="object"&&typeof e.text=="string"?e.text:"").join(""):""}function Qa(t){return t==="session/prompt"?{stopReason:"stopped"}:{}}function Xa(t,e){for(let n of t.split(/\r?\n/)){let s=n.trim();if(s)return s.length>e?`${s.slice(0,e)}\u2026`:s}}var gu,yu,mu,an,gy,Ya,yy,Ys,wy,Yt=V(()=>{"use strict";au();du();Xi();uu();Va();dt();gu="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",yu=hu(gu,16),mu=hu(gu,16),an="hydra_session_";gy=1e3,Ya=300*1e3,yy=64,Ys=class t{sessionId;cwd;agentId;agent;upstreamSessionId;agentMeta;agentCapabilities;agentArgs;parentSessionId;forkedFromSessionId;forkedFromMessageId;originatingClient;_interactive;get interactive(){return this._interactive}_priority;get priority(){return this._priority}title;currentModel;currentMode;_currentUsage;updatedAt;createdAt;clients=new Map;historyStore;promptQueue=[];currentEntry;promptInFlight=!1;queueWriteChain=Promise.resolve();closed=!1;closing=!1;closeInFlight;closeHandlers=[];titleHandlers=[];scheduleSynopsisHook;broadcastHandlers=[];lastCancelAt=0;static CANCEL_ERROR_WINDOW_MS=2e3;forceCancelling=!1;_firstPromptSeeded=!1;get firstPromptSeeded(){return this._firstPromptSeeded}promptStartedAt;appendCount=0;historyMaxEntries;compactEvery;inFlightPermissions=new Set;internalPromptCapture;idleTimeoutMs;idleTimer;idleEventTimer;idleEventTimeoutMs;lastRecordedAt;spawnReplacementAgent;listSessions;logger;transformChain;extensionCommands;extensionCommandsUnsub;pendingClaims=new Map;agentChangeHandlers=[];agentAdvertisedCommands=[];agentAdvertisedModes=[];agentAdvertisedModels=[];agentCommandsHandlers=[];agentModesHandlers=[];agentModelsHandlers=[];availableAgentsFn;modelHandlers=[];modeHandlers=[];interactiveHandlers=[];priorityHandlers=[];usageHandlers=[];cumulativeCost=0;get currentUsage(){if(!this._currentUsage&&!this.cumulativeCost)return;let e=this._currentUsage??{},n=this.cumulativeCost+(e.costAmount??0);return{...e,costAmount:n||void 0,cumulativeCost:void 0}}amendInProgress;inFlightExtensionDispatches=new Map;recentlyTerminal=new Map;streamBuffer;streamFilePath;constructor(e){this.sessionId=e.sessionId??`${an}${yu()}`,this.cwd=e.cwd,this.agentId=e.agentId,this.agent=e.agent,this.upstreamSessionId=e.upstreamSessionId,this.agentMeta=e.agentMeta,this.agentCapabilities=e.agentCapabilities,this.agentArgs=e.agentArgs,this.parentSessionId=e.parentSessionId,this.forkedFromSessionId=e.forkedFromSessionId,this.forkedFromMessageId=e.forkedFromMessageId,this.originatingClient=e.originatingClient,this.title=e.title,this.scheduleSynopsisHook=e.scheduleSynopsis,this.currentModel=e.currentModel,this.currentMode=e.currentMode,this._currentUsage=e.currentUsage,this.cumulativeCost=e.currentUsage?.cumulativeCost??0,e.agentCommands&&e.agentCommands.length>0&&(this.agentAdvertisedCommands=[...e.agentCommands]),e.agentModes&&e.agentModes.length>0&&(this.agentAdvertisedModes=[...e.agentModes]),e.agentModels&&e.agentModels.length>0&&(this.agentAdvertisedModels=[...e.agentModels]),this.idleTimeoutMs=e.idleTimeoutMs??0,this.idleEventTimeoutMs=e.idleEventTimeoutMs??3e4,this.spawnReplacementAgent=e.spawnReplacementAgent,this.availableAgentsFn=e.availableAgents,this.listSessions=e.listSessions,this.logger=e.logger,this.transformChain=e.transformChain??[],this.extensionCommands=e.extensionCommands,this.extensionCommands&&(this.extensionCommandsUnsub=this.extensionCommands.onChange(()=>{this.closed||this.broadcastMergedCommands()})),e.firstPromptSeeded&&(this._firstPromptSeeded=!0),this._interactive=e.interactive,this._priority=e.priority,this.historyStore=e.historyStore,this.historyMaxEntries=e.historyMaxEntries??gy,this.compactEvery=Math.max(1,Math.floor(this.historyMaxEntries*.2)),this.updatedAt=Date.now(),this.createdAt=e.createdAt??this.updatedAt,this.lastRecordedAt=this.updatedAt,this.wireAgent(this.agent),this.scheduleIdleCheck(),this.notifyChain("session.opened",{})}broadcastMergedCommands(){this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"available_commands_update",availableCommands:this.mergedAvailableCommands()}})}broadcastAvailableModes(){this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"available_modes_update",availableModes:this.agentAdvertisedModes}})}broadcastAvailableModels(){let e={sessionUpdate:"current_model_update",availableModels:[...this.agentAdvertisedModels]};this.currentModel!==void 0&&this.currentModel.length>0&&(e.currentModel=this.currentModel),this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:e})}wireAgent(e){e.connection.onNotification("session/update",n=>{if(this.internalPromptCapture){xy(this.internalPromptCapture,n);return}this.runResponseChain(n)}),e.connection.onRequest("session/request_permission",async n=>this.handlePermissionRequest(n)),typeof e.connection.onOrphanError=="function"&&e.connection.onOrphanError(n=>{this.handleOrphanError(n)}),e.onExit(()=>{this.agent===e&&this.markClosed({deleteRecord:!1})})}handleOrphanError(e){let n=Date.now()-this.lastCancelAt;if(this.lastCancelAt===0||n>t.CANCEL_ERROR_WINDOW_MS){this.logger?.warn(`agent ${this.agentId} sent uncorrelated error frame code=${e.code} message=${e.message}`);return}this.lastCancelAt=0,this.logger?.warn(`agent ${this.agentId} rejected session/cancel code=${e.code} message=${e.message}`),this.broadcastQueueNotification("hydra-acp/cancel_failed",{sessionId:this.sessionId,code:e.code,message:e.message})}async runResponseChain(e,n=new Set,s=0){let r=e,i=this.injectCumulativeCost(e);for(let d=s;d<this.transformChain.length;d++){let c=this.transformChain[d];if(n.has(c.name)||!c.intercepts.has("response:session/update"))continue;let l=`t_${mu()}`,f;try{f=await c.connection.request("hydra-acp/transformer/message",{token:l,phase:"response",method:"session/update",direction:"agent\u2192client",sessionId:this.sessionId,envelope:i})}catch(p){this.logger?.warn(`transformer ${c.name} error on response:session/update: ${p.message}`);continue}let u=f?.action??"continue";if(u==="stop")return;if(u==="processing"){let p=d,g=i,h=new Set(n);await new Promise(w=>{let v=setTimeout(()=>{this.pendingClaims.delete(l)&&(this.broadcastQueueNotification("hydra-acp/transformer/abandoned_request",{sessionId:this.sessionId,token:l,transformerName:c.name}),this.runResponseChain(g,new Set([...h,c.name]),p+1).then(w))},Ya);typeof v.unref=="function"&&v.unref(),this.pendingClaims.set(l,{resolve:()=>w(),timer:v,transformerName:c.name,method:"session/update",envelope:g,chainIdx:p,originatedBy:h,side:"response"})});return}n.add(c.name)}let o=Ay(i);if(o!==null){this.setAgentAdvertisedCommands(o);return}let a=ky(i);if(a!==null){this.setAgentAdvertisedModes(a);return}if(this.maybeApplyAgentModel(i)){this.recordAndBroadcast("session/update",i);return}if(this.maybeApplyAgentMode(i)){this.recordAndBroadcast("session/update",i);return}if(this.maybeApplyAgentConfigOption(i)){this.recordAndBroadcast("session/update",this.mergeAgentOptionIntoEnvelope(i));return}if(this.maybeApplyAgentUsage(r)){this.recordAndBroadcast("session/update",i);return}this.maybeApplyAgentSessionInfo(i),this.recordAndBroadcast("session/update",i)}onAgentChange(e){this.agentChangeHandlers.push(e)}get attachedCount(){return this.clients.size}connectedClients(e){let n=[];for(let s of this.clients.values()){if(e&&s.clientId===e)continue;let r={clientId:s.clientId};s.clientInfo?.name&&(r.name=s.clientInfo.name),s.clientInfo?.version&&(r.version=s.clientInfo.version),n.push(r)}return n}get turnStartedAt(){return this.promptStartedAt}get awaitingInput(){return this.inFlightPermissions.size>0}async getHistorySnapshot(e="inline"){return this.historyStore?this.historyStore.load(this.sessionId,{tools:e}).catch(()=>[]):[]}onBroadcast(e){return this.broadcastHandlers.push(e),()=>{let n=this.broadcastHandlers.indexOf(e);n>=0&&this.broadcastHandlers.splice(n,1)}}attach(e,n,s={}){if(this.closed)throw bt(new Error("session is closed"),B.SessionNotFound);if(this.clients.has(e.clientId))throw bt(new Error(`client ${e.clientId} is already attached`),B.AlreadyAttached);return this.clients.set(e.clientId,e),this.updatedAt=Date.now(),n==="none"?Promise.resolve({entries:[],appliedPolicy:n}):n==="pending_only"?Promise.resolve({entries:this.buildStateSnapshotReplay(),appliedPolicy:n}):this.loadReplay(n,s)}async loadReplay(e,n){let s=o=>n.raw?o:lu(o),r=await this.getHistorySnapshot(n.toolContent??"inline"),i=this.buildStateSnapshotReplay();if(e==="after_message"){let o=n.afterMessageId?Ga(r,n.afterMessageId):-1;return o<0?{entries:[...i,...s(r)],appliedPolicy:"full"}:{entries:[...i,...s(r.slice(o+1))],appliedPolicy:"after_message"}}return{entries:[...i,...s(r)],appliedPolicy:"full"}}buildStateSnapshotReplay(){let e=[],n=this.sessionId,s=Date.now();if(this.title!==void 0&&this.title.length>0&&e.push({method:"session/update",params:{sessionId:n,update:{sessionUpdate:"session_info_update",title:this.title}},recordedAt:s}),this.currentModel!==void 0&&this.currentModel.length>0||this.agentAdvertisedModels.length>0){let i={sessionUpdate:"current_model_update"};this.currentModel!==void 0&&this.currentModel.length>0&&(i.currentModel=this.currentModel),this.agentAdvertisedModels.length>0&&(i.availableModels=[...this.agentAdvertisedModels]),e.push({method:"session/update",params:{sessionId:n,update:i},recordedAt:s})}this.currentMode!==void 0&&this.currentMode.length>0&&e.push({method:"session/update",params:{sessionId:n,update:{sessionUpdate:"current_mode_update",currentModeId:this.currentMode}},recordedAt:s});let r=this.mergedAvailableCommands();if(r.length>0&&e.push({method:"session/update",params:{sessionId:n,update:{sessionUpdate:"available_commands_update",availableCommands:r}},recordedAt:s}),this.agentAdvertisedModes.length>0&&e.push({method:"session/update",params:{sessionId:n,update:{sessionUpdate:"available_modes_update",availableModes:[...this.agentAdvertisedModes]}},recordedAt:s}),this.currentUsage!==void 0){let i=this.currentUsage,o={sessionUpdate:"usage_update"};if(typeof i.used=="number"&&(o.used=i.used),typeof i.size=="number"&&(o.size=i.size),typeof i.costAmount=="number"||typeof i.costCurrency=="string"){let a={};typeof i.costAmount=="number"&&(a.amount=i.costAmount),typeof i.costCurrency=="string"&&(a.currency=i.costCurrency),o.cost=a}Object.keys(o).length>1&&e.push({method:"session/update",params:{sessionId:n,update:o},recordedAt:s})}return e}replayPendingPermissions(e){for(let n of this.inFlightPermissions)n.addClient(e)}detach(e){let n=this.clients.get(e);n&&(this.clients.delete(e),this.updatedAt=Date.now(),this.broadcastClientDisconnected(n))}broadcastClientDisconnected(e){let n={clientId:e.clientId};e.clientInfo?.name&&(n.name=e.clientInfo.name),e.clientInfo?.version&&(n.version=e.clientInfo.version);let s={sessionUpdate:"client_disconnected",client:n,timestamp:new Date().toISOString()};for(let r of this.clients.values())r.connection.notify("session/update",{sessionId:this.sessionId,update:s}).catch(()=>{})}async prompt(e,n){let s=this.clients.get(e);if(!s)throw bt(new Error("client not attached"),B.SessionNotFound);if(this.closing)throw bt(new Error("session is closing; new prompts cannot be accepted"),B.SessionClosing);let r=Ks();if(this.maybeSeedTitleFromPrompt(n),this._firstPromptSeeded=!0,!(wt((n??{})._meta).ancillary===!0)&&this._interactive!==!0){this._interactive=!0;for(let o of this.interactiveHandlers)try{o(!0)}catch{}}return this.enqueueUserPrompt(s,n,r)}broadcastPromptReceived(e){let n={clientId:e.originator.clientId};e.originator.name&&(n.name=e.originator.name),e.originator.version&&(n.version=e.originator.version),this.promptStartedAt=Date.now(),this.recordAndBroadcast("session/update",{sessionId:this.sessionId,update:{sessionUpdate:"prompt_received",messageId:e.messageId,prompt:e.prompt,sentBy:n}},e.clientId);let s=Vs(e.prompt);s.length>0&&this.recordAndBroadcast("session/update",{sessionId:this.sessionId,update:{sessionUpdate:"user_message_chunk",content:{type:"text",text:s},_meta:{"hydra-acp":{compatFor:"prompt_received"}}}},e.clientId)}broadcastTurnComplete(e,n,s,r){let i=n&&typeof n=="object"&&"stopReason"in n&&typeof n.stopReason=="string"?n.stopReason:void 0,o={sessionUpdate:"turn_complete",messageId:Ks()};i!==void 0&&(o.stopReason=i);let a=this.amendInProgress;a&&s!==void 0&&a.cancelledMessageId===s&&(o._meta={"hydra-acp":{amended:{cancelledMessageId:a.cancelledMessageId,newMessageId:a.newMessageId}}}),this.promptStartedAt=void 0,s!==void 0&&i!==void 0&&this.recordTerminal(s,i),this.recordAndBroadcast("session/update",{sessionId:this.sessionId,update:o},r?void 0:e),a&&s!==void 0&&a.cancelledMessageId===s&&this.broadcastPromptAmended(a)}recordTerminal(e,n){for(this.recentlyTerminal.set(e,{stopReason:n,terminatedAt:Date.now()});this.recentlyTerminal.size>yy;){let s=this.recentlyTerminal.keys().next().value;if(s===void 0)break;this.recentlyTerminal.delete(s)}}broadcastPromptAmended(e){let n=this.findUserEntry(e.newMessageId);if(!n)return;let s={sessionId:this.sessionId,cancelledMessageId:e.cancelledMessageId,newMessageId:e.newMessageId,prompt:n.prompt,originator:n.originator,amendedAt:Date.now()};this.broadcastQueueNotification("hydra-acp/prompt/amended",s)}findUserEntry(e){if(this.currentEntry?.messageId===e&&this.currentEntry.kind==="user")return this.currentEntry;let n=this.promptQueue.find(s=>s.messageId===e&&s.kind==="user");return n?.kind==="user"?n:void 0}visibleQueueDepth(){let e=this.currentEntry?.kind==="user"&&!this.currentEntry.cancelled?1:0;for(let n of this.promptQueue)n.kind==="user"&&!n.cancelled&&(e+=1);return e}broadcastQueueAdded(e,n){let s=this.visibleQueueDepth(),r=n?.position??Math.max(0,s-1),i={sessionId:this.sessionId,messageId:e.messageId,originator:e.originator,prompt:e.prompt,position:r,queueDepth:s,enqueuedAt:e.enqueuedAt};n?.amending!==void 0&&(i._meta={"hydra-acp":{amending:n.amending}}),this.broadcastQueueNotification("hydra-acp/prompt_queue/added",i)}broadcastQueueUpdated(e,n){this.broadcastQueueNotification("hydra-acp/prompt_queue/updated",{sessionId:this.sessionId,messageId:e,prompt:n})}broadcastQueueRemoved(e,n){this.broadcastQueueNotification("hydra-acp/prompt_queue/removed",{sessionId:this.sessionId,messageId:e,reason:n})}broadcastQueueNotification(e,n){for(let s of this.clients.values())s.connection.notify(e,n).catch(()=>{})}queueSnapshot(){let e=[],n=0;this.currentEntry?.kind==="user"&&!this.currentEntry.cancelled&&e.push({messageId:this.currentEntry.messageId,originator:this.currentEntry.originator,prompt:this.currentEntry.prompt,position:n++,enqueuedAt:this.currentEntry.enqueuedAt});for(let s of this.promptQueue)s.kind!=="user"||s.cancelled||e.push({messageId:s.messageId,originator:s.originator,prompt:s.prompt,position:n++,enqueuedAt:s.enqueuedAt});return e}async flushPersistWrites(){await this.queueWriteChain.catch(()=>{})}replayPersistedQueue(e){for(let n of e){let s={clientId:`hydra-resurrected_${n.messageId}`};n.originator.clientInfo.name!==void 0&&(s.name=n.originator.clientInfo.name),n.originator.clientInfo.version!==void 0&&(s.version=n.originator.clientInfo.version);let r={kind:"user",messageId:n.messageId,originator:s,clientId:s.clientId,prompt:n.prompt,enqueuedAt:n.enqueuedAt,cancelled:!1,resolve:()=>{},reject:()=>{}};this.promptQueue.push(r),this.broadcastQueueAdded(r)}this.drainQueue()}cancelQueuedPrompt(e){if(this.currentEntry?.messageId===e)return{cancelled:!1,reason:"already_running"};let n=this.promptQueue.findIndex(r=>r.messageId===e);if(n<0)return{cancelled:!1,reason:"not_found"};let s=this.promptQueue[n];return s.cancelled=!0,this.promptQueue.splice(n,1),s.kind==="user"&&(this.broadcastQueueRemoved(e,"cancelled"),this.persistRewrite()),this.amendInProgress?.newMessageId===e&&(this.amendInProgress=void 0),s.resolve({stopReason:"cancelled"}),{cancelled:!0,reason:"ok"}}updateQueuedPrompt(e,n){if(this.currentEntry?.messageId===e)return{updated:!1,reason:"already_running"};let s=this.promptQueue.find(r=>r.messageId===e);return!s||s.kind!=="user"?{updated:!1,reason:"not_found"}:(s.prompt=n,this.broadcastQueueUpdated(e,n),this.persistRewrite(),{updated:!0,reason:"ok"})}amendPrompt(e,n){let s=this.clients.get(e);if(!s)throw bt(new Error("client not attached"),B.SessionNotFound);let{targetMessageId:r,prompt:i,replaceQueue:o,onTargetCompleted:a}=n;if(this.currentEntry?.messageId===r&&this.currentEntry.kind==="user"&&!this.currentEntry.cancelled&&this.amendInProgress===void 0)return this.amendOnHead(s,i,r,o);let d=this.promptQueue.find(l=>l.messageId===r&&l.kind==="user");if(d&&d.kind==="user"&&!d.cancelled)return d.prompt=i,this.broadcastQueueUpdated(r,i),this.persistRewrite(),{amended:!0,reason:"ok",messageId:r};let c=this.recentlyTerminal.get(r);return c?c.stopReason==="cancelled"?{amended:!1,reason:"target_cancelled"}:a==="send_anyway"?{amended:!1,reason:"target_completed",messageId:this.enqueueAmendmentAsFollowUp(s,i)}:{amended:!1,reason:"target_completed"}:{amended:!1,reason:"target_not_found"}}amendOnHead(e,n,s,r){let i=Ks(),o={clientId:e.clientId};if(e.clientInfo?.name&&(o.name=e.clientInfo.name),e.clientInfo?.version&&(o.version=e.clientInfo.version),r){let d=[];for(let c of this.promptQueue){if(c.kind==="user"&&!c.cancelled){c.cancelled=!0,this.broadcastQueueRemoved(c.messageId,"cancelled"),c.resolve({stopReason:"cancelled"});continue}d.push(c)}this.promptQueue=d}let a={kind:"user",messageId:i,originator:o,clientId:e.clientId,prompt:n,enqueuedAt:Date.now(),cancelled:!1,wasAmend:!0,resolve:()=>{},reject:()=>{}};return this.promptQueue.unshift(a),this.persistRewrite(),this.broadcastQueueAdded(a,{amending:s,position:1}),this.amendInProgress={cancelledMessageId:s,newMessageId:i},this.cancelExtensionDispatch(s,"amended"),this.agent.connection.notify("session/cancel",{sessionId:this.upstreamSessionId}).catch(()=>{}),{amended:!0,reason:"ok",messageId:i}}enqueueAmendmentAsFollowUp(e,n){let s=Ks(),r={clientId:e.clientId};e.clientInfo?.name&&(r.name=e.clientInfo.name),e.clientInfo?.version&&(r.version=e.clientInfo.version);let i={kind:"user",messageId:s,originator:r,clientId:e.clientId,prompt:n,enqueuedAt:Date.now(),cancelled:!1,resolve:()=>{},reject:()=>{}};return this.promptQueue.push(i),this.persistRewrite(),this.broadcastQueueAdded(i),this.drainQueue(),s}async cancel(e){if(!this.clients.get(e))throw bt(new Error("client not attached"),B.SessionNotFound);this.lastCancelAt=Date.now(),this.currentEntry?.kind==="user"&&this.currentEntry.messageId!==void 0&&this.cancelExtensionDispatch(this.currentEntry.messageId,"cancelled"),await this.forwardRequest("session/cancel",{sessionId:this.sessionId},new Set,0,"notification")}addTransformer(e){let n=this.transformChain.findIndex(s=>s.name===e.name);n>=0?this.transformChain[n]=e:this.transformChain.push(e),e.intercepts.has("lifecycle:session.opened")&&e.connection.notify("hydra-acp/transformer/session_event",{event:"session.opened",sessionId:this.sessionId}).catch(()=>{})}async forwardRequest(e,n,s=new Set,r=0,i="request"){let o=this.rewriteForAgent(n);for(let a=r;a<this.transformChain.length;a++){let d=this.transformChain[a];if(s.has(d.name))continue;let c=`request:${e}`;if(!d.intercepts.has(c))continue;let l=`t_${mu()}`,f;try{f=await d.connection.request("hydra-acp/transformer/message",{token:l,phase:"request",method:e,direction:"client\u2192agent",sessionId:this.sessionId,envelope:o})}catch(p){this.logger?.warn(`transformer ${d.name} error on ${c}: ${p.message}`);continue}let u=f?.action??"continue";if(u==="stop")return i==="notification"?void 0:f?.payload??Qa(e);if(u==="processing"){let p=a,g=o,h=new Set(s);return new Promise(w=>{let v=setTimeout(()=>{this.pendingClaims.delete(l)&&(this.broadcastQueueNotification("hydra-acp/transformer/abandoned_request",{sessionId:this.sessionId,token:l,transformerName:d.name}),this.forwardRequest(e,g,new Set([...h,d.name]),p+1,i).then(w).catch(()=>w(i==="notification"?void 0:Qa(e))))},Ya);typeof v.unref=="function"&&v.unref(),this.pendingClaims.set(l,{resolve:w,timer:v,transformerName:d.name,method:e,envelope:g,chainIdx:p,originatedBy:h,side:"request",tailKind:i})})}s.add(d.name)}if(i==="notification"){await this.agent.connection.notify(e,o);return}return this.agent.connection.request(e,o)}dischargeClaim(e,n){let s=this.pendingClaims.get(e);return s?(clearTimeout(s.timer),this.pendingClaims.delete(e),s.resolve(n),!0):!1}keepAliveClaim(e,n){let s=this.pendingClaims.get(e);if(!s)return!1;clearTimeout(s.timer);let r=typeof n=="number"&&n>0?Math.min(n*1.5,1800*1e3):Ya,i=setTimeout(()=>{if(this.pendingClaims.delete(e))if(this.broadcastQueueNotification("hydra-acp/transformer/abandoned_request",{sessionId:this.sessionId,token:e,transformerName:s.transformerName}),s.side==="response")this.runResponseChain(s.envelope,new Set([...s.originatedBy,s.transformerName]),s.chainIdx+1).then(()=>s.resolve(void 0));else{let o=s.tailKind??"request";this.forwardRequest(s.method,s.envelope,new Set([...s.originatedBy,s.transformerName]),s.chainIdx+1,o).then(s.resolve).catch(()=>s.resolve(o==="notification"?void 0:Qa(s.method)))}},r);return typeof i.unref=="function"&&i.unref(),s.timer=i,!0}async emitToChain(e,n,s){let r=this.transformChain.findIndex(a=>a.name===e),i=r>=0?r+1:0,o=new Set([e]);if(n==="session/update"){await this.runResponseChain(s,o,i);return}return this.forwardRequest(n,s,o,i)}rewriteForAgent(e){if(e&&typeof e=="object"&&!Array.isArray(e)){let n=e;if(n.sessionId===this.sessionId)return{...n,sessionId:this.upstreamSessionId}}return e}async close(e={}){if(!this.closed)return this.closeInFlight?this.closeInFlight:(this.closing=!0,this.closeInFlight=this.doClose(e),this.closeInFlight)}async doClose(e){this.logger?.info(`session ${this.sessionId} closing deleteRecord=${e.deleteRecord??!1}`),this.cancelIdleTimer(),await this.agent.kill().catch(()=>{}),this.markClosed({deleteRecord:e.deleteRecord??!1})}onClose(e){this.closeHandlers.push(e)}onTitleChange(e){this.titleHandlers.push(e)}retitle(e){return this.runTitleCommand(e)}retitleFromAgent(){return this.runTitleCommand("")}setTitle(e){let n=e.trim();if(!(!n||n===this.title)){this.title=n,this.recordAndBroadcast("session/update",{sessionId:this.sessionId,update:{sessionUpdate:"session_info_update",title:n,updatedAt:new Date().toISOString()}});for(let s of this.titleHandlers)try{s(n)}catch{}}}maybeSeedTitleFromPrompt(e){if(this.firstPromptSeeded)return;let s=Vs((e??{}).prompt),r=Xa(s,200);r&&(r.startsWith("/")||(this._firstPromptSeeded=!0,this.setTitle(r)))}maybeApplyAgentModel(e){let s=(e??{}).update??{};if(s.sessionUpdate!=="current_model_update")return!1;let r=as(s.availableModels);r.length>0&&this.setAgentAdvertisedModels(r);let i=typeof s.currentModel=="string"?s.currentModel:typeof s.model=="string"?s.model:void 0;if(i===void 0)return!0;let o=i.trim();if(!o||o===this.currentModel)return!0;this.logger?.info(`live current_model_update: sessionId=${this.sessionId} ${JSON.stringify(this.currentModel)} \u2192 ${JSON.stringify(o)}`),this.currentModel=o;for(let a of this.modelHandlers)try{a(o)}catch{}return this.broadcastConfigOptions(),!0}maybeApplyAgentConfigOption(e){let s=(e??{}).update??{};if(s.sessionUpdate!=="config_option_update")return!1;let r=s.configOptions;if(!Array.isArray(r))return!0;for(let i of r){if(!i||typeof i!="object")continue;let o=i;if(o.id==="model"){let a=as(o.options);a.length>0&&this.setAgentAdvertisedModels(a);let d=o.currentValue;if(typeof d=="string"){let c=d.trim();c&&c!==this.currentModel&&(this.logger?.info(`live config_option_update(model): sessionId=${this.sessionId} ${JSON.stringify(this.currentModel)} \u2192 ${JSON.stringify(c)}`),this.applyModelChange(c))}}else if(o.id==="mode"){let a=Qs(o.options);a.length>0&&this.setAgentAdvertisedModes(a);let d=o.currentValue;if(typeof d=="string"){let c=d.trim();c&&c!==this.currentMode&&(this.logger?.info(`live config_option_update(mode): sessionId=${this.sessionId} ${JSON.stringify(this.currentMode)} \u2192 ${JSON.stringify(c)}`),this.applyModeChange(c))}}}return!0}maybeApplyAgentMode(e){let s=(e??{}).update??{};if(s.sessionUpdate!=="current_mode_update")return!1;let r=typeof s.currentModeId=="string"?s.currentModeId:typeof s.currentMode=="string"?s.currentMode:typeof s.mode=="string"?s.mode:void 0;if(r===void 0)return!0;let i=r.trim();if(!i||i===this.currentMode)return!0;this.logger?.info(`current_mode_update: sessionId=${this.sessionId} ${JSON.stringify(this.currentMode)} \u2192 ${JSON.stringify(i)}`),this.currentMode=i;for(let o of this.modeHandlers)try{o(i)}catch{}return this.broadcastConfigOptions(),!0}maybeApplyAgentUsage(e){let s=(e??{}).update??{};if(s.sessionUpdate!=="usage_update")return!1;let r={...this._currentUsage??{}},i=!1;if(typeof s.used=="number"&&r.used!==s.used&&(r.used=s.used,i=!0),typeof s.size=="number"&&r.size!==s.size&&(r.size=s.size,i=!0),s.cost&&typeof s.cost=="object"){let a=s.cost;typeof a.amount=="number"&&r.costAmount!==a.amount&&(r.costAmount=a.amount,i=!0),typeof a.currency=="string"&&r.costCurrency!==a.currency&&(r.costCurrency=a.currency,i=!0)}if(!i)return!0;this._currentUsage=r;let o=this.currentUsage??r;for(let a of this.usageHandlers)try{a(o)}catch{}return!0}accumulateAndResetCost(){let e=this._currentUsage?.costAmount;if(!e)return;this.cumulativeCost+=e;let n={...this._currentUsage??{},cumulativeCost:this.cumulativeCost,costAmount:void 0};this._currentUsage=n;for(let s of this.usageHandlers)try{s(n)}catch{}}injectCumulativeCost(e){if(!this.cumulativeCost||!e||typeof e!="object")return e;let n=e;if(!n.update||typeof n.update!="object")return e;let s=n.update;if(s.sessionUpdate!=="usage_update"||!s.cost||typeof s.cost!="object")return e;let r=s.cost;return typeof r.amount!="number"?e:{...n,update:{...s,cost:{...r,amount:this.cumulativeCost+r.amount}}}}get totalUsage(){return this.currentUsage}setAgentAdvertisedCommands(e){if(vy(this.agentAdvertisedCommands,e)){this.broadcastMergedCommands();return}this.agentAdvertisedCommands=e;for(let n of this.agentCommandsHandlers)try{n(e)}catch{}this.broadcastMergedCommands()}setAgentAdvertisedModes(e){if(Iy(this.agentAdvertisedModes,e)){this.broadcastAvailableModes();return}this.agentAdvertisedModes=e;for(let n of this.agentModesHandlers)try{n(e)}catch{}this.broadcastAvailableModes()}setAgentAdvertisedModels(e){if(this.logger?.info(`setAgentAdvertisedModels: sessionId=${this.sessionId} currentModel=${JSON.stringify(this.currentModel)} newList=[${e.map(n=>n.modelId).join(",")}]`),Sy(this.agentAdvertisedModels,e)){this.broadcastAvailableModels();return}this.agentAdvertisedModels=e;for(let n of this.agentModelsHandlers)try{n(e)}catch{}this.broadcastAvailableModels()}onAgentCommandsChange(e){this.agentCommandsHandlers.push(e)}onAgentModesChange(e){this.agentModesHandlers.push(e)}onAgentModelsChange(e){this.agentModelsHandlers.push(e)}onModelChange(e){this.modelHandlers.push(e)}onModeChange(e){this.modeHandlers.push(e)}onInteractiveChange(e){this.interactiveHandlers.push(e)}onPriorityChange(e){this.priorityHandlers.push(e)}setPriority(e){let n=e===void 0||e<=0?void 0:Math.floor(e);if(n!==this._priority){this._priority=n,this.updatedAt=Date.now();for(let s of this.priorityHandlers)try{s(n)}catch{}}}applyModelChange(e){let n=e.trim();if(!n)return;if(n!==this.currentModel){this.logger?.info(`applyModelChange: sessionId=${this.sessionId} ${JSON.stringify(this.currentModel)} \u2192 ${JSON.stringify(n)}`),this.currentModel=n;for(let r of this.modelHandlers)try{r(n)}catch{}}let s={sessionUpdate:"current_model_update",currentModel:n};this.agentAdvertisedModels.length>0&&(s.availableModels=[...this.agentAdvertisedModels]),this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:s}),this.broadcastConfigOptions()}applyModeChange(e){let n=e.trim();if(!n)return;if(n!==this.currentMode){this.logger?.info(`applyModeChange: sessionId=${this.sessionId} ${JSON.stringify(this.currentMode)} \u2192 ${JSON.stringify(n)}`),this.currentMode=n;for(let r of this.modeHandlers)try{r(n)}catch{}}let s={sessionUpdate:"current_mode_update",currentModeId:n};this.agentAdvertisedModes.length>0&&(s.availableModes=[...this.agentAdvertisedModes]),this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:s}),this.broadcastConfigOptions()}buildConfigOptions(){let e=[];if(this.agentAdvertisedModels.length>0){let r=this.agentAdvertisedModels.map(o=>({value:o.modelId,name:o.name??o.modelId,...o.description!==void 0?{description:o.description}:{}})),i=this.currentModel&&r.some(o=>o.value===this.currentModel)?this.currentModel:r[0].value;e.push({id:"model",name:"Model",category:"model",type:"select",currentValue:i,options:r})}if(this.agentAdvertisedModes.length>0){let r=this.agentAdvertisedModes.map(o=>({value:o.id,name:o.name??o.id,...o.description!==void 0?{description:o.description}:{}})),i=this.currentMode&&r.some(o=>o.value===this.currentMode)?this.currentMode:r[0].value;e.push({id:"mode",name:"Session Mode",category:"mode",type:"select",currentValue:i,options:r})}let s=(this.availableAgentsFn?.()??[]).map(r=>({value:r.id,name:r.name??r.id,...r.description!==void 0?{description:r.description}:{}}));return s.some(r=>r.value===this.agentId)||s.unshift({value:this.agentId,name:this.agentId}),e.push({id:"agent",name:"Agent",category:"_hydra_agent",type:"select",currentValue:this.agentId,options:s}),e}broadcastConfigOptions(){this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"config_option_update",configOptions:this.buildConfigOptions()}})}mergeAgentOptionIntoEnvelope(e){if(!e||typeof e!="object")return e;let n=e;if(!n.update||typeof n.update!="object")return e;let s=n.update,r=Array.isArray(s.configOptions)?[...s.configOptions]:[];if(r.some(a=>a&&typeof a=="object"&&a.id==="agent"))return e;let o=this.buildConfigOptions().find(a=>a.id==="agent");return o?{...n,update:{...s,configOptions:[...r,o]}}:e}onUsageChange(e){this.usageHandlers.push(e)}mergedAvailableCommands(){let e=[{name:"hydra",description:"Hydra session command (kill, restart, title, agent <agent>)"},{name:"model",description:"Switch model; omit arg to list available models"},{name:"mode",description:"Switch mode; omit arg to list available modes"},{name:"sessions",description:"List all sessions"},{name:"help",description:"Show available commands"}];if(this.extensionCommands)for(let{name:n,command:s}of this.extensionCommands.list()){let r=s.verb?`hydra ${n} ${s.verb}`:`hydra ${n}`,o={name:s.argsHint?`${r} ${s.argsHint}`:r};if(s.description&&(o.description=s.description),e.push(o),n.startsWith("hydra-acp-")){let a=n.slice(10);if(a.length>0){let d=s.verb?`hydra ${a} ${s.verb}`:`hydra ${a}`,l={name:s.argsHint?`${d} ${s.argsHint}`:d};s.description&&(l.description=s.description),e.push(l)}}}return e.push(...this.agentAdvertisedCommands),e}agentOnlyAdvertisedCommands(){return[...this.agentAdvertisedCommands]}availableModes(){return[...this.agentAdvertisedModes]}availableModels(){return[...this.agentAdvertisedModels]}maybeApplyAgentSessionInfo(e){let s=(e??{}).update??{};if(s.sessionUpdate!=="session_info_update"||typeof s.title!="string")return;let r=s.title.trim();if(!(!r||r===this.title)){this.title=r,this._firstPromptSeeded=!0;for(let i of this.titleHandlers)try{i(r)}catch{}}}async handleSlashCommand(e,n){let r=e.slice(6).trim().match(/^(\S+)(?:\s+([\s\S]*))?$/),i=r?.[1]??"",o=(r?.[2]??"").trim();if(i==="")return{stopReason:"end_turn"};let a=n!==void 0;if(Gi.some(f=>f.verb===i))switch(i){case"title":return a?this.runTitleCommandInline(o):this.runTitleCommand(o);case"agent":return a?this.runAgentCommandInline(o):this.runAgentCommand(o);case"kill":return this.runKillCommand();case"restart":return a?this.runRestartCommandInline():this.runRestartCommand();default:{let f=new Error(`no dispatcher for /hydra verb ${i}`);throw f.code=B.InternalError,f}}if(this.extensionCommands?.has(i))return a?this.runExtensionCommandInline(i,o,n):this.runExtensionCommand(i,o);let d=`hydra-acp-${i}`;if(this.extensionCommands?.has(d))return a?this.runExtensionCommandInline(d,o,n):this.runExtensionCommand(d,o);let c=Gi.map(f=>f.verb);if(this.extensionCommands){let f=new Set;for(let{name:u}of this.extensionCommands.list())f.has(u)||(c.push(u),f.add(u))}let l=new Error(`unknown /hydra verb: ${i} (known: ${c.join(", ")})`);throw l.code=B.InvalidParams,l}runExtensionCommand(e,n){return this.enqueuePrompt(()=>this.runExtensionCommandInline(e,n,void 0))}async runExtensionCommandInline(e,n,s){let r=this.extensionCommands?.get(e);if(!r)return this.emitExtensionReply(`extension "${e}" is no longer connected`);let i=n.match(/^(\S+)(?:\s+([\s\S]*))?$/),o=i?.[1]??"",a=(i?.[2]??"").trim();if(!r.commands.some(g=>g.verb===o)){let g=r.commands.map(h=>h.verb).join(", ");return this.emitExtensionReply(`/hydra ${e}${o?` ${o}`:""}: unknown verb (known: ${g||"(none)"})`)}let d={sessionId:this.sessionId,verb:o,args:a};s!==void 0&&(d.messageId=s);let c=()=>{},l=new Promise(g=>{c=g});s!==void 0&&this.inFlightExtensionDispatches.set(s,{extensionName:e,connection:r.connection,cancel:g=>c({stopReason:"cancelled",reason:g})});let f,u=!1;try{let g=r.connection.request("hydra-acp/commands/invoke",d),h=await Promise.race([g,l]);if(h&&typeof h=="object"&&h.stopReason==="cancelled"&&"reason"in h)return u=!0,this.logger?.info(`extension ${e} ${o} cancelled (cancelExtensionDispatch); abandoning in-flight commands/invoke`),{stopReason:"cancelled"};f=h}catch(g){return this.emitExtensionReply(`${e} ${o}: ${g.message}`)}finally{s!==void 0&&!u&&this.inFlightExtensionDispatches.delete(s)}let p=f&&typeof f=="object"&&typeof f.text=="string"?f.text:"";return p.length>0?this.emitExtensionReply(p):{stopReason:"end_turn"}}cancelExtensionDispatch(e,n){let s=this.inFlightExtensionDispatches.get(e);if(!s)return!1;this.inFlightExtensionDispatches.delete(e);try{s.connection.notify("hydra-acp/commands/cancel",{sessionId:this.sessionId,messageId:e,reason:n})}catch(r){this.logger?.warn(`notify commands/cancel to ${s.extensionName} failed: ${r.message}`)}return s.cancel(n),!0}emitExtensionReply(e){return this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"agent_message_chunk",content:{type:"text",text:`
|
|
11
|
+
`))if(r.trim())try{let i=JSON.parse(r);i&&typeof i.messageId=="string"&&Array.isArray(i.prompt)&&typeof i.enqueuedAt=="number"&&s.push(i)}catch{}return s}async function pu(t){let e=P.queueFile(t);await Vt.unlink(e).catch(()=>{})}var Va=V(()=>{"use strict";ue()});import{customAlphabet as gu}from"nanoid";import*as bu from"fs/promises";function Vs(){return`m_${wu()}`}function He(t){return t.startsWith(an)?t.slice(an.length):t}function bt(t,e){return t.code=e,t}function vy(t,e){if(t!=="session/update")return!1;let s=(e??{}).update?.sessionUpdate;return typeof s=="string"&&by.has(s)}function Iy(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++)if(t[n]?.name!==e[n]?.name||t[n]?.description!==e[n]?.description)return!1;return!0}function Sy(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++)if(t[n]?.id!==e[n]?.id||t[n]?.name!==e[n]?.name||t[n]?.description!==e[n]?.description)return!1;return!0}function ky(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++)if(t[n]?.modelId!==e[n]?.modelId||t[n]?.name!==e[n]?.name||t[n]?.description!==e[n]?.description)return!1;return!0}function Fn(t){if(!Array.isArray(t))return[];let e=[];for(let n of t){if(!n||typeof n!="object"||Array.isArray(n))continue;let s=n,r=typeof s.modelId=="string"&&s.modelId.trim()||typeof s.value=="string"&&s.value.trim()||typeof s.id=="string"&&s.id.trim()||void 0;if(!r)continue;let i={modelId:r};typeof s.name=="string"&&s.name.length>0&&(i.name=s.name),typeof s.description=="string"&&s.description.length>0&&(i.description=s.description),e.push(i)}return e}function ds(t){if(!Array.isArray(t))return[];let e=[];for(let n of t){if(!n||typeof n!="object"||Array.isArray(n))continue;let s=n,r=typeof s.value=="string"&&s.value.trim()||typeof s.id=="string"&&s.id.trim()||void 0;if(!r)continue;let i={id:r};typeof s.name=="string"&&s.name.length>0&&(i.name=s.name),typeof s.description=="string"&&s.description.length>0&&(i.description=s.description),e.push(i)}return e}function xy(t){let n=(t??{}).update??{};if(n.sessionUpdate!=="available_modes_update")return null;let s=n.availableModes;if(!Array.isArray(s))return[];let r=[];for(let i of s){if(!i||typeof i!="object")continue;let o=i;if(typeof o.id!="string"||o.id.length===0)continue;let a={id:o.id};typeof o.name=="string"&&(a.name=o.name),typeof o.description=="string"&&(a.description=o.description),r.push(a)}return r}function Ay(t,e){let s=(e??{}).update??{};if(s.sessionUpdate!=="agent_message_chunk")return;let r=s.content??{};typeof r.text=="string"&&t.chunks.push(r.text)}function Cy(t){let n=(t??{}).update??{};if(n.sessionUpdate!=="available_commands_update")return null;let s=n.availableCommands??n.commands;if(!Array.isArray(s))return[];let r=[];for(let i of s){if(!i||typeof i!="object")continue;let o=i;if(typeof o.name!="string"||o.name.length===0)continue;let a={name:o.name};typeof o.description=="string"&&(a.description=o.description),r.push(a)}return r}function Ry(t,e){if(t!=="session/update"||!e||typeof e!="object")return e;let n=e;return!n.update||typeof n.update!="object"||Array.isArray(n.update)||typeof n.update.messageId=="string"?e:{...e,update:{...n.update,messageId:Vs()}}}function Ga(t,e){for(let n=0;n<t.length;n++){let s=t[n];if(!s||s.method!=="session/update")continue;if(s.params?.update?.messageId===e)return n}return-1}function Ty(t){if(!t||typeof t!="object")return;let e=t.toolCall;if(!e||typeof e!="object")return;let n=e.toolCallId;return typeof n=="string"?n:void 0}function Ey(t){let e=Py(t.result),n={sessionUpdate:"permission_resolved"};return t.toolCallId!==void 0&&(n.toolCallId=t.toolCallId),e&&(n.outcome=e,e.kind==="selected"&&typeof e.optionId=="string"&&(n.chosenOptionId=e.optionId)),n.resolvedBy=My(t.resolver),n}function Py(t){if(!t||typeof t!="object")return;let e=t.outcome;if(!e||typeof e!="object")return;let n=e.kind;if(typeof n!="string")return;let s={kind:n},r=e.optionId;typeof r=="string"&&(s.optionId=r);let i=e.reason;return typeof i=="string"&&(s.reason=i),s}function My(t){let e={clientId:t.clientId};return t.clientInfo?.name&&(e.name=t.clientInfo.name),t.clientInfo?.version&&(e.version=t.clientInfo.version),e}function Ys(t){return typeof t=="string"?t:Array.isArray(t)?t.map(e=>e&&typeof e=="object"&&typeof e.text=="string"?e.text:"").join(""):""}function Qa(t){return t==="session/prompt"?{stopReason:"stopped"}:{}}function hu(t){let e=t.name&&t.name!==t.id?`${t.id} (${t.name}) \u2014 \u25B6 ${t.currentValue}`:`${t.id} \u2014 \u25B6 ${t.currentValue}`;if(t.options.length===0)return e;let n=Math.max(...t.options.map(r=>r.value.length)),s=t.options.map(r=>{let i=r.value===t.currentValue?"\u25B6":"\xB7",o=r.name&&r.name!==r.value,a=o?r.value.padEnd(n):r.value;return o?` ${i} ${a} ${r.name}`:` ${i} ${a}`});return`${e}
|
|
12
|
+
${s.join(`
|
|
13
|
+
`)}`}function Xa(t,e){for(let n of t.split(/\r?\n/)){let s=n.trim();if(s)return s.length>e?`${s.slice(0,e)}\u2026`:s}}var yu,wu,mu,an,yy,Ya,wy,Qs,by,Yt=V(()=>{"use strict";au();du();Xi();uu();Va();dt();yu="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",wu=gu(yu,16),mu=gu(yu,16),an="hydra_session_";yy=1e3,Ya=300*1e3,wy=64,Qs=class t{sessionId;cwd;agentId;agent;upstreamSessionId;agentMeta;agentCapabilities;agentArgs;parentSessionId;forkedFromSessionId;forkedFromMessageId;originatingClient;_interactive;get interactive(){return this._interactive}_priority;get priority(){return this._priority}title;currentModel;currentMode;_currentUsage;updatedAt;createdAt;clients=new Map;historyStore;promptQueue=[];currentEntry;promptInFlight=!1;queueWriteChain=Promise.resolve();closed=!1;closing=!1;closeInFlight;closeHandlers=[];titleHandlers=[];scheduleSynopsisHook;broadcastHandlers=[];lastCancelAt=0;static CANCEL_ERROR_WINDOW_MS=2e3;forceCancelling=!1;_firstPromptSeeded=!1;get firstPromptSeeded(){return this._firstPromptSeeded}promptStartedAt;appendCount=0;historyMaxEntries;compactEvery;inFlightPermissions=new Set;internalPromptCapture;idleTimeoutMs;idleTimer;idleEventTimer;idleEventTimeoutMs;lastRecordedAt;spawnReplacementAgent;listSessions;logger;transformChain;extensionCommands;extensionCommandsUnsub;pendingClaims=new Map;agentChangeHandlers=[];agentAdvertisedCommands=[];agentAdvertisedModes=[];agentAdvertisedModels=[];agentAdvertisedConfigOptions=[];agentCommandsHandlers=[];agentModesHandlers=[];agentModelsHandlers=[];availableAgentsFn;modelHandlers=[];modeHandlers=[];interactiveHandlers=[];priorityHandlers=[];usageHandlers=[];cumulativeCost=0;get currentUsage(){if(!this._currentUsage&&!this.cumulativeCost)return;let e=this._currentUsage??{},n=this.cumulativeCost+(e.costAmount??0);return{...e,costAmount:n||void 0,cumulativeCost:void 0}}amendInProgress;inFlightExtensionDispatches=new Map;recentlyTerminal=new Map;streamBuffer;streamFilePath;constructor(e){this.sessionId=e.sessionId??`${an}${wu()}`,this.cwd=e.cwd,this.agentId=e.agentId,this.agent=e.agent,this.upstreamSessionId=e.upstreamSessionId,this.agentMeta=e.agentMeta,this.agentCapabilities=e.agentCapabilities,this.agentArgs=e.agentArgs,this.parentSessionId=e.parentSessionId,this.forkedFromSessionId=e.forkedFromSessionId,this.forkedFromMessageId=e.forkedFromMessageId,this.originatingClient=e.originatingClient,this.title=e.title,this.scheduleSynopsisHook=e.scheduleSynopsis,this.currentModel=e.currentModel,this.currentMode=e.currentMode,this._currentUsage=e.currentUsage,this.cumulativeCost=e.currentUsage?.cumulativeCost??0,e.agentCommands&&e.agentCommands.length>0&&(this.agentAdvertisedCommands=[...e.agentCommands]),e.agentModes&&e.agentModes.length>0&&(this.agentAdvertisedModes=[...e.agentModes]),e.agentModels&&e.agentModels.length>0&&(this.agentAdvertisedModels=[...e.agentModels]),this.idleTimeoutMs=e.idleTimeoutMs??0,this.idleEventTimeoutMs=e.idleEventTimeoutMs??3e4,this.spawnReplacementAgent=e.spawnReplacementAgent,this.availableAgentsFn=e.availableAgents,this.listSessions=e.listSessions,this.logger=e.logger,this.transformChain=e.transformChain??[],this.extensionCommands=e.extensionCommands,this.extensionCommands&&(this.extensionCommandsUnsub=this.extensionCommands.onChange(()=>{this.closed||this.broadcastMergedCommands()})),e.firstPromptSeeded&&(this._firstPromptSeeded=!0),this._interactive=e.interactive,this._priority=e.priority,this.historyStore=e.historyStore,this.historyMaxEntries=e.historyMaxEntries??yy,this.compactEvery=Math.max(1,Math.floor(this.historyMaxEntries*.2)),this.updatedAt=Date.now(),this.createdAt=e.createdAt??this.updatedAt,this.lastRecordedAt=this.updatedAt,this.wireAgent(this.agent),this.scheduleIdleCheck(),this.notifyChain("session.opened",{})}broadcastMergedCommands(){this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"available_commands_update",availableCommands:this.mergedAvailableCommands()}})}broadcastAvailableModes(){this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"available_modes_update",availableModes:this.agentAdvertisedModes}})}broadcastAvailableModels(){let e={sessionUpdate:"current_model_update",availableModels:[...this.agentAdvertisedModels]};this.currentModel!==void 0&&this.currentModel.length>0&&(e.currentModel=this.currentModel),this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:e})}wireAgent(e){e.connection.onNotification("session/update",n=>{if(this.internalPromptCapture){Ay(this.internalPromptCapture,n);return}this.runResponseChain(n)}),e.connection.onRequest("session/request_permission",async n=>this.handlePermissionRequest(n)),typeof e.connection.onOrphanError=="function"&&e.connection.onOrphanError(n=>{this.handleOrphanError(n)}),e.onExit(()=>{this.agent===e&&this.markClosed({deleteRecord:!1})})}handleOrphanError(e){let n=Date.now()-this.lastCancelAt;if(this.lastCancelAt===0||n>t.CANCEL_ERROR_WINDOW_MS){this.logger?.warn(`agent ${this.agentId} sent uncorrelated error frame code=${e.code} message=${e.message}`);return}this.lastCancelAt=0,this.logger?.warn(`agent ${this.agentId} rejected session/cancel code=${e.code} message=${e.message}`),this.broadcastQueueNotification("hydra-acp/cancel_failed",{sessionId:this.sessionId,code:e.code,message:e.message})}async runResponseChain(e,n=new Set,s=0){let r=e,i=this.injectCumulativeCost(e);for(let d=s;d<this.transformChain.length;d++){let c=this.transformChain[d];if(n.has(c.name)||!c.intercepts.has("response:session/update"))continue;let l=`t_${mu()}`,f;try{f=await c.connection.request("hydra-acp/transformer/message",{token:l,phase:"response",method:"session/update",direction:"agent\u2192client",sessionId:this.sessionId,envelope:i})}catch(p){this.logger?.warn(`transformer ${c.name} error on response:session/update: ${p.message}`);continue}let u=f?.action??"continue";if(u==="stop")return;if(u==="processing"){let p=d,g=i,h=new Set(n);await new Promise(w=>{let v=setTimeout(()=>{this.pendingClaims.delete(l)&&(this.broadcastQueueNotification("hydra-acp/transformer/abandoned_request",{sessionId:this.sessionId,token:l,transformerName:c.name}),this.runResponseChain(g,new Set([...h,c.name]),p+1).then(w))},Ya);typeof v.unref=="function"&&v.unref(),this.pendingClaims.set(l,{resolve:()=>w(),timer:v,transformerName:c.name,method:"session/update",envelope:g,chainIdx:p,originatedBy:h,side:"response"})});return}n.add(c.name)}let o=Cy(i);if(o!==null){this.setAgentAdvertisedCommands(o);return}let a=xy(i);if(a!==null){this.setAgentAdvertisedModes(a);return}if(this.maybeApplyAgentModel(i)){this.recordAndBroadcast("session/update",i);return}if(this.maybeApplyAgentMode(i)){this.recordAndBroadcast("session/update",i);return}if(this.maybeApplyAgentConfigOption(i)){this.recordAndBroadcast("session/update",this.mergeAgentOptionIntoEnvelope(i));return}if(this.maybeApplyAgentUsage(r)){this.recordAndBroadcast("session/update",i);return}this.maybeApplyAgentSessionInfo(i),this.recordAndBroadcast("session/update",i)}onAgentChange(e){this.agentChangeHandlers.push(e)}get attachedCount(){return this.clients.size}connectedClients(e){let n=[];for(let s of this.clients.values()){if(e&&s.clientId===e)continue;let r={clientId:s.clientId};s.clientInfo?.name&&(r.name=s.clientInfo.name),s.clientInfo?.version&&(r.version=s.clientInfo.version),n.push(r)}return n}get turnStartedAt(){return this.promptStartedAt}get awaitingInput(){return this.inFlightPermissions.size>0}async getHistorySnapshot(e="inline"){return this.historyStore?this.historyStore.load(this.sessionId,{tools:e}).catch(()=>[]):[]}onBroadcast(e){return this.broadcastHandlers.push(e),()=>{let n=this.broadcastHandlers.indexOf(e);n>=0&&this.broadcastHandlers.splice(n,1)}}attach(e,n,s={}){if(this.closed)throw bt(new Error("session is closed"),B.SessionNotFound);if(this.clients.has(e.clientId))throw bt(new Error(`client ${e.clientId} is already attached`),B.AlreadyAttached);return this.clients.set(e.clientId,e),this.updatedAt=Date.now(),n==="none"?Promise.resolve({entries:[],appliedPolicy:n}):n==="pending_only"?Promise.resolve({entries:this.buildStateSnapshotReplay(),appliedPolicy:n}):this.loadReplay(n,s)}async loadReplay(e,n){let s=o=>n.raw?o:lu(o),r=await this.getHistorySnapshot(n.toolContent??"inline"),i=this.buildStateSnapshotReplay();if(e==="after_message"){let o=n.afterMessageId?Ga(r,n.afterMessageId):-1;return o<0?{entries:[...i,...s(r)],appliedPolicy:"full"}:{entries:[...i,...s(r.slice(o+1))],appliedPolicy:"after_message"}}return{entries:[...i,...s(r)],appliedPolicy:"full"}}buildStateSnapshotReplay(){let e=[],n=this.sessionId,s=Date.now();if(this.title!==void 0&&this.title.length>0&&e.push({method:"session/update",params:{sessionId:n,update:{sessionUpdate:"session_info_update",title:this.title}},recordedAt:s}),this.currentModel!==void 0&&this.currentModel.length>0||this.agentAdvertisedModels.length>0){let i={sessionUpdate:"current_model_update"};this.currentModel!==void 0&&this.currentModel.length>0&&(i.currentModel=this.currentModel),this.agentAdvertisedModels.length>0&&(i.availableModels=[...this.agentAdvertisedModels]),e.push({method:"session/update",params:{sessionId:n,update:i},recordedAt:s})}this.currentMode!==void 0&&this.currentMode.length>0&&e.push({method:"session/update",params:{sessionId:n,update:{sessionUpdate:"current_mode_update",currentModeId:this.currentMode}},recordedAt:s});let r=this.mergedAvailableCommands();if(r.length>0&&e.push({method:"session/update",params:{sessionId:n,update:{sessionUpdate:"available_commands_update",availableCommands:r}},recordedAt:s}),this.agentAdvertisedModes.length>0&&e.push({method:"session/update",params:{sessionId:n,update:{sessionUpdate:"available_modes_update",availableModes:[...this.agentAdvertisedModes]}},recordedAt:s}),this.currentUsage!==void 0){let i=this.currentUsage,o={sessionUpdate:"usage_update"};if(typeof i.used=="number"&&(o.used=i.used),typeof i.size=="number"&&(o.size=i.size),typeof i.costAmount=="number"||typeof i.costCurrency=="string"){let a={};typeof i.costAmount=="number"&&(a.amount=i.costAmount),typeof i.costCurrency=="string"&&(a.currency=i.costCurrency),o.cost=a}Object.keys(o).length>1&&e.push({method:"session/update",params:{sessionId:n,update:o},recordedAt:s})}return e}replayPendingPermissions(e){for(let n of this.inFlightPermissions)n.addClient(e)}detach(e){let n=this.clients.get(e);n&&(this.clients.delete(e),this.updatedAt=Date.now(),this.broadcastClientDisconnected(n))}broadcastClientDisconnected(e){let n={clientId:e.clientId};e.clientInfo?.name&&(n.name=e.clientInfo.name),e.clientInfo?.version&&(n.version=e.clientInfo.version);let s={sessionUpdate:"client_disconnected",client:n,timestamp:new Date().toISOString()};for(let r of this.clients.values())r.connection.notify("session/update",{sessionId:this.sessionId,update:s}).catch(()=>{})}async prompt(e,n){let s=this.clients.get(e);if(!s)throw bt(new Error("client not attached"),B.SessionNotFound);if(this.closing)throw bt(new Error("session is closing; new prompts cannot be accepted"),B.SessionClosing);let r=Vs();if(this.maybeSeedTitleFromPrompt(n),this._firstPromptSeeded=!0,!(wt((n??{})._meta).ancillary===!0)&&this._interactive!==!0){this._interactive=!0;for(let o of this.interactiveHandlers)try{o(!0)}catch{}}return this.enqueueUserPrompt(s,n,r)}broadcastPromptReceived(e){let n={clientId:e.originator.clientId};e.originator.name&&(n.name=e.originator.name),e.originator.version&&(n.version=e.originator.version),this.promptStartedAt=Date.now(),this.recordAndBroadcast("session/update",{sessionId:this.sessionId,update:{sessionUpdate:"prompt_received",messageId:e.messageId,prompt:e.prompt,sentBy:n}},e.clientId);let s=Ys(e.prompt);s.length>0&&this.recordAndBroadcast("session/update",{sessionId:this.sessionId,update:{sessionUpdate:"user_message_chunk",content:{type:"text",text:s},_meta:{"hydra-acp":{compatFor:"prompt_received"}}}},e.clientId)}broadcastTurnComplete(e,n,s,r){let i=n&&typeof n=="object"&&"stopReason"in n&&typeof n.stopReason=="string"?n.stopReason:void 0,o={sessionUpdate:"turn_complete",messageId:Vs()};i!==void 0&&(o.stopReason=i);let a=this.amendInProgress;a&&s!==void 0&&a.cancelledMessageId===s&&(o._meta={"hydra-acp":{amended:{cancelledMessageId:a.cancelledMessageId,newMessageId:a.newMessageId}}}),this.promptStartedAt=void 0,s!==void 0&&i!==void 0&&this.recordTerminal(s,i),this.recordAndBroadcast("session/update",{sessionId:this.sessionId,update:o},r?void 0:e),a&&s!==void 0&&a.cancelledMessageId===s&&this.broadcastPromptAmended(a)}recordTerminal(e,n){for(this.recentlyTerminal.set(e,{stopReason:n,terminatedAt:Date.now()});this.recentlyTerminal.size>wy;){let s=this.recentlyTerminal.keys().next().value;if(s===void 0)break;this.recentlyTerminal.delete(s)}}broadcastPromptAmended(e){let n=this.findUserEntry(e.newMessageId);if(!n)return;let s={sessionId:this.sessionId,cancelledMessageId:e.cancelledMessageId,newMessageId:e.newMessageId,prompt:n.prompt,originator:n.originator,amendedAt:Date.now()};this.broadcastQueueNotification("hydra-acp/prompt/amended",s)}findUserEntry(e){if(this.currentEntry?.messageId===e&&this.currentEntry.kind==="user")return this.currentEntry;let n=this.promptQueue.find(s=>s.messageId===e&&s.kind==="user");return n?.kind==="user"?n:void 0}visibleQueueDepth(){let e=this.currentEntry?.kind==="user"&&!this.currentEntry.cancelled?1:0;for(let n of this.promptQueue)n.kind==="user"&&!n.cancelled&&(e+=1);return e}broadcastQueueAdded(e,n){let s=this.visibleQueueDepth(),r=n?.position??Math.max(0,s-1),i={sessionId:this.sessionId,messageId:e.messageId,originator:e.originator,prompt:e.prompt,position:r,queueDepth:s,enqueuedAt:e.enqueuedAt};n?.amending!==void 0&&(i._meta={"hydra-acp":{amending:n.amending}}),this.broadcastQueueNotification("hydra-acp/prompt_queue/added",i)}broadcastQueueUpdated(e,n){this.broadcastQueueNotification("hydra-acp/prompt_queue/updated",{sessionId:this.sessionId,messageId:e,prompt:n})}broadcastQueueRemoved(e,n){this.broadcastQueueNotification("hydra-acp/prompt_queue/removed",{sessionId:this.sessionId,messageId:e,reason:n})}broadcastQueueNotification(e,n){for(let s of this.clients.values())s.connection.notify(e,n).catch(()=>{})}queueSnapshot(){let e=[],n=0;this.currentEntry?.kind==="user"&&!this.currentEntry.cancelled&&e.push({messageId:this.currentEntry.messageId,originator:this.currentEntry.originator,prompt:this.currentEntry.prompt,position:n++,enqueuedAt:this.currentEntry.enqueuedAt});for(let s of this.promptQueue)s.kind!=="user"||s.cancelled||e.push({messageId:s.messageId,originator:s.originator,prompt:s.prompt,position:n++,enqueuedAt:s.enqueuedAt});return e}async flushPersistWrites(){await this.queueWriteChain.catch(()=>{})}replayPersistedQueue(e){for(let n of e){let s={clientId:`hydra-resurrected_${n.messageId}`};n.originator.clientInfo.name!==void 0&&(s.name=n.originator.clientInfo.name),n.originator.clientInfo.version!==void 0&&(s.version=n.originator.clientInfo.version);let r={kind:"user",messageId:n.messageId,originator:s,clientId:s.clientId,prompt:n.prompt,enqueuedAt:n.enqueuedAt,cancelled:!1,resolve:()=>{},reject:()=>{}};this.promptQueue.push(r),this.broadcastQueueAdded(r)}this.drainQueue()}cancelQueuedPrompt(e){if(this.currentEntry?.messageId===e)return{cancelled:!1,reason:"already_running"};let n=this.promptQueue.findIndex(r=>r.messageId===e);if(n<0)return{cancelled:!1,reason:"not_found"};let s=this.promptQueue[n];return s.cancelled=!0,this.promptQueue.splice(n,1),s.kind==="user"&&(this.broadcastQueueRemoved(e,"cancelled"),this.persistRewrite()),this.amendInProgress?.newMessageId===e&&(this.amendInProgress=void 0),s.resolve({stopReason:"cancelled"}),{cancelled:!0,reason:"ok"}}updateQueuedPrompt(e,n){if(this.currentEntry?.messageId===e)return{updated:!1,reason:"already_running"};let s=this.promptQueue.find(r=>r.messageId===e);return!s||s.kind!=="user"?{updated:!1,reason:"not_found"}:(s.prompt=n,this.broadcastQueueUpdated(e,n),this.persistRewrite(),{updated:!0,reason:"ok"})}amendPrompt(e,n){let s=this.clients.get(e);if(!s)throw bt(new Error("client not attached"),B.SessionNotFound);let{targetMessageId:r,prompt:i,replaceQueue:o,onTargetCompleted:a}=n;if(this.currentEntry?.messageId===r&&this.currentEntry.kind==="user"&&!this.currentEntry.cancelled&&this.amendInProgress===void 0)return this.amendOnHead(s,i,r,o);let d=this.promptQueue.find(l=>l.messageId===r&&l.kind==="user");if(d&&d.kind==="user"&&!d.cancelled)return d.prompt=i,this.broadcastQueueUpdated(r,i),this.persistRewrite(),{amended:!0,reason:"ok",messageId:r};let c=this.recentlyTerminal.get(r);return c?c.stopReason==="cancelled"?{amended:!1,reason:"target_cancelled"}:a==="send_anyway"?{amended:!1,reason:"target_completed",messageId:this.enqueueAmendmentAsFollowUp(s,i)}:{amended:!1,reason:"target_completed"}:{amended:!1,reason:"target_not_found"}}amendOnHead(e,n,s,r){let i=Vs(),o={clientId:e.clientId};if(e.clientInfo?.name&&(o.name=e.clientInfo.name),e.clientInfo?.version&&(o.version=e.clientInfo.version),r){let d=[];for(let c of this.promptQueue){if(c.kind==="user"&&!c.cancelled){c.cancelled=!0,this.broadcastQueueRemoved(c.messageId,"cancelled"),c.resolve({stopReason:"cancelled"});continue}d.push(c)}this.promptQueue=d}let a={kind:"user",messageId:i,originator:o,clientId:e.clientId,prompt:n,enqueuedAt:Date.now(),cancelled:!1,wasAmend:!0,resolve:()=>{},reject:()=>{}};return this.promptQueue.unshift(a),this.persistRewrite(),this.broadcastQueueAdded(a,{amending:s,position:1}),this.amendInProgress={cancelledMessageId:s,newMessageId:i},this.cancelExtensionDispatch(s,"amended"),this.agent.connection.notify("session/cancel",{sessionId:this.upstreamSessionId}).catch(()=>{}),{amended:!0,reason:"ok",messageId:i}}enqueueAmendmentAsFollowUp(e,n){let s=Vs(),r={clientId:e.clientId};e.clientInfo?.name&&(r.name=e.clientInfo.name),e.clientInfo?.version&&(r.version=e.clientInfo.version);let i={kind:"user",messageId:s,originator:r,clientId:e.clientId,prompt:n,enqueuedAt:Date.now(),cancelled:!1,resolve:()=>{},reject:()=>{}};return this.promptQueue.push(i),this.persistRewrite(),this.broadcastQueueAdded(i),this.drainQueue(),s}async cancel(e){if(!this.clients.get(e))throw bt(new Error("client not attached"),B.SessionNotFound);this.lastCancelAt=Date.now(),this.currentEntry?.kind==="user"&&this.currentEntry.messageId!==void 0&&this.cancelExtensionDispatch(this.currentEntry.messageId,"cancelled"),await this.forwardRequest("session/cancel",{sessionId:this.sessionId},new Set,0,"notification")}addTransformer(e){let n=this.transformChain.findIndex(s=>s.name===e.name);n>=0?this.transformChain[n]=e:this.transformChain.push(e),e.intercepts.has("lifecycle:session.opened")&&e.connection.notify("hydra-acp/transformer/session_event",{event:"session.opened",sessionId:this.sessionId}).catch(()=>{})}async forwardRequest(e,n,s=new Set,r=0,i="request"){let o=this.rewriteForAgent(n);for(let a=r;a<this.transformChain.length;a++){let d=this.transformChain[a];if(s.has(d.name))continue;let c=`request:${e}`;if(!d.intercepts.has(c))continue;let l=`t_${mu()}`,f;try{f=await d.connection.request("hydra-acp/transformer/message",{token:l,phase:"request",method:e,direction:"client\u2192agent",sessionId:this.sessionId,envelope:o})}catch(p){this.logger?.warn(`transformer ${d.name} error on ${c}: ${p.message}`);continue}let u=f?.action??"continue";if(u==="stop")return i==="notification"?void 0:f?.payload??Qa(e);if(u==="processing"){let p=a,g=o,h=new Set(s);return new Promise(w=>{let v=setTimeout(()=>{this.pendingClaims.delete(l)&&(this.broadcastQueueNotification("hydra-acp/transformer/abandoned_request",{sessionId:this.sessionId,token:l,transformerName:d.name}),this.forwardRequest(e,g,new Set([...h,d.name]),p+1,i).then(w).catch(()=>w(i==="notification"?void 0:Qa(e))))},Ya);typeof v.unref=="function"&&v.unref(),this.pendingClaims.set(l,{resolve:w,timer:v,transformerName:d.name,method:e,envelope:g,chainIdx:p,originatedBy:h,side:"request",tailKind:i})})}s.add(d.name)}if(i==="notification"){await this.agent.connection.notify(e,o);return}return this.agent.connection.request(e,o)}dischargeClaim(e,n){let s=this.pendingClaims.get(e);return s?(clearTimeout(s.timer),this.pendingClaims.delete(e),s.resolve(n),!0):!1}keepAliveClaim(e,n){let s=this.pendingClaims.get(e);if(!s)return!1;clearTimeout(s.timer);let r=typeof n=="number"&&n>0?Math.min(n*1.5,1800*1e3):Ya,i=setTimeout(()=>{if(this.pendingClaims.delete(e))if(this.broadcastQueueNotification("hydra-acp/transformer/abandoned_request",{sessionId:this.sessionId,token:e,transformerName:s.transformerName}),s.side==="response")this.runResponseChain(s.envelope,new Set([...s.originatedBy,s.transformerName]),s.chainIdx+1).then(()=>s.resolve(void 0));else{let o=s.tailKind??"request";this.forwardRequest(s.method,s.envelope,new Set([...s.originatedBy,s.transformerName]),s.chainIdx+1,o).then(s.resolve).catch(()=>s.resolve(o==="notification"?void 0:Qa(s.method)))}},r);return typeof i.unref=="function"&&i.unref(),s.timer=i,!0}async emitToChain(e,n,s){let r=this.transformChain.findIndex(a=>a.name===e),i=r>=0?r+1:0,o=new Set([e]);if(n==="session/update"){await this.runResponseChain(s,o,i);return}return this.forwardRequest(n,s,o,i)}rewriteForAgent(e){if(e&&typeof e=="object"&&!Array.isArray(e)){let n=e;if(n.sessionId===this.sessionId)return{...n,sessionId:this.upstreamSessionId}}return e}async close(e={}){if(!this.closed)return this.closeInFlight?this.closeInFlight:(this.closing=!0,this.closeInFlight=this.doClose(e),this.closeInFlight)}async doClose(e){this.logger?.info(`session ${this.sessionId} closing deleteRecord=${e.deleteRecord??!1}`),this.cancelIdleTimer(),await this.agent.kill().catch(()=>{}),this.markClosed({deleteRecord:e.deleteRecord??!1})}onClose(e){this.closeHandlers.push(e)}onTitleChange(e){this.titleHandlers.push(e)}retitle(e){return this.runTitleCommand(e)}retitleFromAgent(){return this.runTitleCommand("")}setTitle(e){let n=e.trim();if(!(!n||n===this.title)){this.title=n,this.recordAndBroadcast("session/update",{sessionId:this.sessionId,update:{sessionUpdate:"session_info_update",title:n,updatedAt:new Date().toISOString()}});for(let s of this.titleHandlers)try{s(n)}catch{}}}maybeSeedTitleFromPrompt(e){if(this.firstPromptSeeded)return;let s=Ys((e??{}).prompt),r=Xa(s,200);r&&(r.startsWith("/")||(this._firstPromptSeeded=!0,this.setTitle(r)))}maybeApplyAgentModel(e){let s=(e??{}).update??{};if(s.sessionUpdate!=="current_model_update")return!1;let r=Fn(s.availableModels);r.length>0&&this.setAgentAdvertisedModels(r);let i=typeof s.currentModel=="string"?s.currentModel:typeof s.model=="string"?s.model:void 0;if(i===void 0)return!0;let o=i.trim();if(!o||o===this.currentModel)return!0;this.logger?.info(`live current_model_update: sessionId=${this.sessionId} ${JSON.stringify(this.currentModel)} \u2192 ${JSON.stringify(o)}`),this.currentModel=o;for(let a of this.modelHandlers)try{a(o)}catch{}return this.broadcastConfigOptions(),!0}maybeApplyAgentConfigOption(e){let s=(e??{}).update??{};if(s.sessionUpdate!=="config_option_update")return!1;let r=s.configOptions;if(!Array.isArray(r))return!0;for(let i of r){if(!i||typeof i!="object")continue;let o=i;if(o.id==="model"){let a=Fn(o.options);a.length>0&&this.setAgentAdvertisedModels(a);let d=o.currentValue;if(typeof d=="string"){let c=d.trim();c&&c!==this.currentModel&&(this.logger?.info(`live config_option_update(model): sessionId=${this.sessionId} ${JSON.stringify(this.currentModel)} \u2192 ${JSON.stringify(c)}`),this.applyModelChange(c))}}else if(o.id==="mode"){let a=ds(o.options);a.length>0&&this.setAgentAdvertisedModes(a);let d=o.currentValue;if(typeof d=="string"){let c=d.trim();c&&c!==this.currentMode&&(this.logger?.info(`live config_option_update(mode): sessionId=${this.sessionId} ${JSON.stringify(this.currentMode)} \u2192 ${JSON.stringify(c)}`),this.applyModeChange(c))}}else if(typeof o.id=="string"&&o.id.trim()){let a=o.id.trim(),d=Fn(o.options);if(d.length>0){let c=ds(o.options),l=c.length>0?c.map(w=>({value:w.id,name:w.name??w.id})):d.map(w=>({value:w.modelId,name:w.name??w.modelId})),f=o.name,u=typeof f=="string"&&f.trim()?f.trim():a,p=o.currentValue,g=typeof p=="string"&&p.trim()?p.trim():l[0]?.value??"",h=this.agentAdvertisedConfigOptions.findIndex(w=>w.id===a);if(h>=0){let w={...this.agentAdvertisedConfigOptions[h]};w.options=l,typeof p=="string"&&p.trim()&&(w.currentValue=p.trim()),this.agentAdvertisedConfigOptions[h]=w}else this.agentAdvertisedConfigOptions.push({id:a,name:u,category:"other",type:"select",currentValue:g,options:l})}}}return!0}maybeApplyAgentMode(e){let s=(e??{}).update??{};if(s.sessionUpdate!=="current_mode_update")return!1;let r=typeof s.currentModeId=="string"?s.currentModeId:typeof s.currentMode=="string"?s.currentMode:typeof s.mode=="string"?s.mode:void 0;if(r===void 0)return!0;let i=r.trim();if(!i||i===this.currentMode)return!0;this.logger?.info(`current_mode_update: sessionId=${this.sessionId} ${JSON.stringify(this.currentMode)} \u2192 ${JSON.stringify(i)}`),this.currentMode=i;for(let o of this.modeHandlers)try{o(i)}catch{}return this.broadcastConfigOptions(),!0}maybeApplyAgentUsage(e){let s=(e??{}).update??{};if(s.sessionUpdate!=="usage_update")return!1;let r={...this._currentUsage??{}},i=!1;if(typeof s.used=="number"&&r.used!==s.used&&(r.used=s.used,i=!0),typeof s.size=="number"&&r.size!==s.size&&(r.size=s.size,i=!0),s.cost&&typeof s.cost=="object"){let a=s.cost;typeof a.amount=="number"&&r.costAmount!==a.amount&&(r.costAmount=a.amount,i=!0),typeof a.currency=="string"&&r.costCurrency!==a.currency&&(r.costCurrency=a.currency,i=!0)}if(!i)return!0;this._currentUsage=r;let o=this.currentUsage??r;for(let a of this.usageHandlers)try{a(o)}catch{}return!0}accumulateAndResetCost(){let e=this._currentUsage?.costAmount;if(!e)return;this.cumulativeCost+=e;let n={...this._currentUsage??{},cumulativeCost:this.cumulativeCost,costAmount:void 0};this._currentUsage=n;for(let s of this.usageHandlers)try{s(n)}catch{}}injectCumulativeCost(e){if(!this.cumulativeCost||!e||typeof e!="object")return e;let n=e;if(!n.update||typeof n.update!="object")return e;let s=n.update;if(s.sessionUpdate!=="usage_update"||!s.cost||typeof s.cost!="object")return e;let r=s.cost;return typeof r.amount!="number"?e:{...n,update:{...s,cost:{...r,amount:this.cumulativeCost+r.amount}}}}get totalUsage(){return this.currentUsage}setAgentAdvertisedCommands(e){if(Iy(this.agentAdvertisedCommands,e)){this.broadcastMergedCommands();return}this.agentAdvertisedCommands=e;for(let n of this.agentCommandsHandlers)try{n(e)}catch{}this.broadcastMergedCommands()}setAgentAdvertisedModes(e){if(Sy(this.agentAdvertisedModes,e)){this.broadcastAvailableModes();return}this.agentAdvertisedModes=e;for(let n of this.agentModesHandlers)try{n(e)}catch{}this.broadcastAvailableModes()}setAgentAdvertisedModels(e){if(this.logger?.info(`setAgentAdvertisedModels: sessionId=${this.sessionId} currentModel=${JSON.stringify(this.currentModel)} newList=[${e.map(n=>n.modelId).join(",")}]`),ky(this.agentAdvertisedModels,e)){this.broadcastAvailableModels();return}this.agentAdvertisedModels=e;for(let n of this.agentModelsHandlers)try{n(e)}catch{}this.broadcastAvailableModels()}onAgentCommandsChange(e){this.agentCommandsHandlers.push(e)}onAgentModesChange(e){this.agentModesHandlers.push(e)}onAgentModelsChange(e){this.agentModelsHandlers.push(e)}onModelChange(e){this.modelHandlers.push(e)}onModeChange(e){this.modeHandlers.push(e)}onInteractiveChange(e){this.interactiveHandlers.push(e)}onPriorityChange(e){this.priorityHandlers.push(e)}setPriority(e){let n=e===void 0||e<=0?void 0:Math.floor(e);if(n!==this._priority){this._priority=n,this.updatedAt=Date.now();for(let s of this.priorityHandlers)try{s(n)}catch{}}}applyModelChange(e){let n=e.trim();if(!n)return;if(n!==this.currentModel){this.logger?.info(`applyModelChange: sessionId=${this.sessionId} ${JSON.stringify(this.currentModel)} \u2192 ${JSON.stringify(n)}`),this.currentModel=n;for(let r of this.modelHandlers)try{r(n)}catch{}}let s={sessionUpdate:"current_model_update",currentModel:n};this.agentAdvertisedModels.length>0&&(s.availableModels=[...this.agentAdvertisedModels]),this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:s}),this.broadcastConfigOptions()}applyModeChange(e){let n=e.trim();if(!n)return;if(n!==this.currentMode){this.logger?.info(`applyModeChange: sessionId=${this.sessionId} ${JSON.stringify(this.currentMode)} \u2192 ${JSON.stringify(n)}`),this.currentMode=n;for(let r of this.modeHandlers)try{r(n)}catch{}}let s={sessionUpdate:"current_mode_update",currentModeId:n};this.agentAdvertisedModes.length>0&&(s.availableModes=[...this.agentAdvertisedModes]),this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:s}),this.broadcastConfigOptions()}buildConfigOptions(){let e=[];if(this.agentAdvertisedModels.length>0){let r=this.agentAdvertisedModels.map(o=>({value:o.modelId,name:o.name??o.modelId,...o.description!==void 0?{description:o.description}:{}})),i=this.currentModel&&r.some(o=>o.value===this.currentModel)?this.currentModel:r[0].value;e.push({id:"model",name:"Model",category:"model",type:"select",currentValue:i,options:r})}if(this.agentAdvertisedModes.length>0){let r=this.agentAdvertisedModes.map(o=>({value:o.id,name:o.name??o.id,...o.description!==void 0?{description:o.description}:{}})),i=this.currentMode&&r.some(o=>o.value===this.currentMode)?this.currentMode:r[0].value;e.push({id:"mode",name:"Session Mode",category:"mode",type:"select",currentValue:i,options:r})}let s=(this.availableAgentsFn?.()??[]).map(r=>({value:r.id,name:r.name??r.id,...r.description!==void 0?{description:r.description}:{}}));return s.some(r=>r.value===this.agentId)||s.unshift({value:this.agentId,name:this.agentId}),e.push({id:"agent",name:"Agent",category:"_hydra_agent",type:"select",currentValue:this.agentId,options:s}),e.push(...this.agentAdvertisedConfigOptions),e}broadcastConfigOptions(){this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"config_option_update",configOptions:this.buildConfigOptions()}})}mergeAgentOptionIntoEnvelope(e){if(!e||typeof e!="object")return e;let n=e;if(!n.update||typeof n.update!="object")return e;let s=n.update,r=Array.isArray(s.configOptions)?[...s.configOptions]:[];if(r.some(a=>a&&typeof a=="object"&&a.id==="agent"))return e;let o=this.buildConfigOptions().find(a=>a.id==="agent");return o?{...n,update:{...s,configOptions:[...r,o]}}:e}onUsageChange(e){this.usageHandlers.push(e)}mergedAvailableCommands(){let e=[{name:"hydra",description:"Hydra session command (kill, restart, title, agent <agent>)"},{name:"model",description:"Switch model; omit arg to list available models"},{name:"mode",description:"Switch mode; omit arg to list available modes"},{name:"sessions",description:"List all sessions"},{name:"help",description:"Show available commands"}];if(this.extensionCommands)for(let{name:n,command:s}of this.extensionCommands.list()){let r=s.verb?`hydra ${n} ${s.verb}`:`hydra ${n}`,o={name:s.argsHint?`${r} ${s.argsHint}`:r};if(s.description&&(o.description=s.description),e.push(o),n.startsWith("hydra-acp-")){let a=n.slice(10);if(a.length>0){let d=s.verb?`hydra ${a} ${s.verb}`:`hydra ${a}`,l={name:s.argsHint?`${d} ${s.argsHint}`:d};s.description&&(l.description=s.description),e.push(l)}}}return e.push(...this.agentAdvertisedCommands),e}agentOnlyAdvertisedCommands(){return[...this.agentAdvertisedCommands]}availableModes(){return[...this.agentAdvertisedModes]}availableModels(){return[...this.agentAdvertisedModels]}maybeApplyAgentSessionInfo(e){let s=(e??{}).update??{};if(s.sessionUpdate!=="session_info_update"||typeof s.title!="string")return;let r=s.title.trim();if(!(!r||r===this.title)){this.title=r,this._firstPromptSeeded=!0;for(let i of this.titleHandlers)try{i(r)}catch{}}}async handleSlashCommand(e,n){let r=e.slice(6).trim().match(/^(\S+)(?:\s+([\s\S]*))?$/),i=r?.[1]??"",o=(r?.[2]??"").trim();if(i==="")return{stopReason:"end_turn"};let a=n!==void 0;if(Gi.some(f=>f.verb===i))switch(i){case"title":return a?this.runTitleCommandInline(o):this.runTitleCommand(o);case"agent":return a?this.runAgentCommandInline(o):this.runAgentCommand(o);case"config":return this.handleConfigCommand(`/config ${o}`);case"kill":return this.runKillCommand();case"restart":return a?this.runRestartCommandInline():this.runRestartCommand();default:{let f=new Error(`no dispatcher for /hydra verb ${i}`);throw f.code=B.InternalError,f}}if(this.extensionCommands?.has(i))return a?this.runExtensionCommandInline(i,o,n):this.runExtensionCommand(i,o);let d=`hydra-acp-${i}`;if(this.extensionCommands?.has(d))return a?this.runExtensionCommandInline(d,o,n):this.runExtensionCommand(d,o);let c=Gi.map(f=>f.verb);if(this.extensionCommands){let f=new Set;for(let{name:u}of this.extensionCommands.list())f.has(u)||(c.push(u),f.add(u))}let l=new Error(`unknown /hydra verb: ${i} (known: ${c.join(", ")})`);throw l.code=B.InvalidParams,l}runExtensionCommand(e,n){return this.enqueuePrompt(()=>this.runExtensionCommandInline(e,n,void 0))}async runExtensionCommandInline(e,n,s){let r=this.extensionCommands?.get(e);if(!r)return this.emitExtensionReply(`extension "${e}" is no longer connected`);let i=n.match(/^(\S+)(?:\s+([\s\S]*))?$/),o=i?.[1]??"",a=(i?.[2]??"").trim();if(!r.commands.some(g=>g.verb===o)){let g=r.commands.map(h=>h.verb).join(", ");return this.emitExtensionReply(`/hydra ${e}${o?` ${o}`:""}: unknown verb (known: ${g||"(none)"})`)}let d={sessionId:this.sessionId,verb:o,args:a};s!==void 0&&(d.messageId=s);let c=()=>{},l=new Promise(g=>{c=g});s!==void 0&&this.inFlightExtensionDispatches.set(s,{extensionName:e,connection:r.connection,cancel:g=>c({stopReason:"cancelled",reason:g})});let f,u=!1;try{let g=r.connection.request("hydra-acp/commands/invoke",d),h=await Promise.race([g,l]);if(h&&typeof h=="object"&&h.stopReason==="cancelled"&&"reason"in h)return u=!0,this.logger?.info(`extension ${e} ${o} cancelled (cancelExtensionDispatch); abandoning in-flight commands/invoke`),{stopReason:"cancelled"};f=h}catch(g){return this.emitExtensionReply(`${e} ${o}: ${g.message}`)}finally{s!==void 0&&!u&&this.inFlightExtensionDispatches.delete(s)}let p=f&&typeof f=="object"&&typeof f.text=="string"?f.text:"";return p.length>0?this.emitExtensionReply(p):{stopReason:"end_turn"}}cancelExtensionDispatch(e,n){let s=this.inFlightExtensionDispatches.get(e);if(!s)return!1;this.inFlightExtensionDispatches.delete(e);try{s.connection.notify("hydra-acp/commands/cancel",{sessionId:this.sessionId,messageId:e,reason:n})}catch(r){this.logger?.warn(`notify commands/cancel to ${s.extensionName} failed: ${r.message}`)}return s.cancel(n),!0}emitExtensionReply(e){return this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"agent_message_chunk",content:{type:"text",text:`
|
|
12
14
|
${e}
|
|
13
15
|
`},_meta:{"hydra-acp":{synthetic:!0}}}}),{stopReason:"end_turn"}}async handleSessionsCommand(){let e;if(!this.listSessions)e="_(session listing not available)_";else{let n=await this.listSessions();if(n.length===0)e="_(no sessions)_";else{let s=n.map(r=>{let i=r.sessionId.replace(/^hydra_session_/,"").slice(0,12),o=r.currentModel?` \xB7 ${r.currentModel}`:"",a=r.sessionId===this.sessionId?" \u25C0":"",d=r.title?` ${r.title}`:"";return`\`${i}\` ${r.cwd}${o}${a}${d}`});e=`Sessions (${n.length}):
|
|
14
16
|
${s.join(`
|
|
@@ -21,7 +23,7 @@ ${s}
|
|
|
21
23
|
`},_meta:{"hydra-acp":{synthetic:!0}}}}),Promise.resolve({stopReason:"end_turn"})}async handleModelCommand(e){let n=e.slice(6).trim();if(n===""){let i=this.agentAdvertisedModels,o=this.currentModel,a;if(i.length===0)a=o?`Current model: ${o}`:"_(no models advertised yet)_";else{let d=o?i.some(l=>l.modelId===o):!0,c=i.map(l=>{let f=l.modelId===o?"\u25B6 ":" ",u=l.name&&l.name!==l.modelId?` ${l.name}`:"";return`${f}${l.modelId}${u}`});!d&&o&&c.unshift(`\u25B6 ${o}`),a=c.join(`
|
|
22
24
|
`)}return this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"agent_message_chunk",content:{type:"text",text:`
|
|
23
25
|
${a}
|
|
24
|
-
`},_meta:{"hydra-acp":{synthetic:!0}}}}),{stopReason:"end_turn"}}let s=
|
|
26
|
+
`},_meta:{"hydra-acp":{synthetic:!0}}}}),{stopReason:"end_turn"}}let s=Ks(n,this.agentAdvertisedModels),r=n;if(s.kind==="resolved")r=s.modelId;else if(s.kind==="ambiguous"||s.kind==="unknown"){let i=this.agentAdvertisedModels.map(a=>a.modelId).join(`
|
|
25
27
|
`),o=s.kind==="ambiguous"?`"${n}" matches multiple models: ${s.candidates.join(", ")}`:`"${n}" is not an available model`;return this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"agent_message_chunk",content:{type:"text",text:`
|
|
26
28
|
${o}.
|
|
27
29
|
Available models:
|
|
@@ -29,9 +31,27 @@ Available models:
|
|
|
29
31
|
`},_meta:{"hydra-acp":{synthetic:!0}}}}),{stopReason:"end_turn"}}return await this.forwardRequest("session/set_model",{sessionId:this.sessionId,modelId:r}),{stopReason:"end_turn"}}async handleModeCommand(e){let n=e.slice(5).trim();if(n===""){let r=this.agentAdvertisedModes,i=this.currentMode,o;if(r.length===0)o=i?`Current mode: ${i}`:"_(no modes advertised yet)_";else{let a=i?r.some(c=>c.id===i):!0,d=r.map(c=>{let l=c.id===i?"\u25B6 ":" ",f=c.name&&c.name!==c.id?` ${c.name}`:"";return`${l}${c.id}${f}`});!a&&i&&d.unshift(`\u25B6 ${i}`),o=d.join(`
|
|
30
32
|
`)}return this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"agent_message_chunk",content:{type:"text",text:`
|
|
31
33
|
${o}
|
|
32
|
-
`},_meta:{"hydra-acp":{synthetic:!0}}}}),{stopReason:"end_turn"}}let s=this.agentAdvertisedModes;if(s.length>0&&!s.some(r=>r.id===n)){let r=s.map(i=>i.id).join(", ");throw bt(new Error(`unknown mode: ${n} (known: ${r})`),B.InvalidParams)}return await this.forwardRequest("session/set_mode",{sessionId:this.sessionId,modeId:n}),this.applyModeChange(n),{stopReason:"end_turn"}}
|
|
33
|
-
`)}async seedFromImport(){await this.enqueuePrompt(async()=>{let e=await this.buildSwitchTranscript(this.agentId,{intro:"You are continuing a conversation that was imported from another hydra. Below is the transcript so far.",followup:"Each line is prefixed with its speaker. Treat this as context for the next user message; do not re-respond to earlier turns."});e&&await this.runInternalPrompt(e).catch(()=>{})})}broadcastAgentSwitch(e,n){this.recordAndBroadcast("session/update",{sessionId:this.sessionId,update:{sessionUpdate:"session_info_update",_meta:{"hydra-acp":{synthetic:!0,agentId:n}}}}),this.broadcastConfigOptions()}hasStreamBuffer(){return this.streamBuffer!==void 0}get streamPath(){return this.streamFilePath}openStream(e){if(this.streamBuffer!==void 0)throw new Error(`stream buffer already open for session ${this.sessionId}`);let s=(e.mode??"memory")==="file"&&e.filePathFor!==void 0?e.filePathFor(this.sessionId):void 0,r={};e.capacityBytes!==void 0&&(r.capacityBytes=e.capacityBytes),s!==void 0&&(r.filePath=s),e.fileCapBytes!==void 0&&(r.fileCapBytes=e.fileCapBytes),r.onFileCapReached=()=>{this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"stream_truncated",...s!==void 0?{filePath:s}:{},fileCapBytes:e.fileCapBytes}})};let i=new Qi(r);this.streamBuffer=i,this.streamFilePath=s;let o={capacityBytes:i.capacity};return s!==void 0&&(o.filePath=s),e.fileCapBytes!==void 0&&(o.fileCapBytes=e.fileCapBytes),o}streamWrite(e,n){let s=this.requireStreamBuffer();if(e.length>0){let r=Buffer.from(e,"base64");s.append(r)}return n===!0&&s.close(),{writeCursor:s.writeCursorPos}}async streamRead(e,n,s){let r=this.requireStreamBuffer(),i=Math.max(0,Math.min(n??zs,zs)),o=r.read(e,i);if(o.bytes.length===0&&o.eof!==!0&&s!==void 0&&s>0){let d=await r.waitForData(o.nextCursor,s);(d==="data"||d==="eof")&&(o=r.read(o.nextCursor,i))}let a={bytes:o.bytes.toString("base64"),nextCursor:o.nextCursor};return o.gap!==void 0&&(a.gap=o.gap),o.eof===!0&&(a.eof=!0),a}streamTail(e){let s=this.requireStreamBuffer().tail(e);return{bytes:s.bytes.toString("base64"),startCursor:s.startCursor,endCursor:s.endCursor,truncated:s.truncated}}streamHead(e){let s=this.requireStreamBuffer().head(e);return{bytes:s.bytes.toString("base64"),startCursor:s.startCursor,endCursor:s.endCursor,truncated:s.truncated}}async streamWaitFor(e,n){return this.requireStreamBuffer().waitForData(e,n)}streamGrep(e){return this.requireStreamBuffer().grep(e)}streamInfo(){let e=this.requireStreamBuffer();return{writeCursor:e.writeCursorPos,oldestAvailable:e.oldestAvailable,capacity:e.capacity,closed:e.isClosed}}requireStreamBuffer(){if(this.streamBuffer===void 0){let e=new Error(`session ${this.sessionId} has no stream buffer; POST /v1/sessions/:id/stdin/open first`);throw e.code=B.StreamNotEnabled,e}return this.streamBuffer}markClosed(e){if(this.closed)return;this.closing=!0,this.closed=!0,this.cancelIdleTimer(),this.extensionCommandsUnsub&&(this.extensionCommandsUnsub(),this.extensionCommandsUnsub=void 0);for(let r of[...this.inFlightExtensionDispatches.keys()])this.cancelExtensionDispatch(r,"abandoned");this.currentEntry?.kind==="user"&&!this.recentlyTerminal.has(this.currentEntry.messageId)&&this.broadcastTurnComplete(this.currentEntry.clientId,{stopReason:"interrupted"},this.currentEntry.messageId,this.currentEntry.wasAmend),this.currentEntry=void 0;let n=this.promptQueue;this.promptQueue=[];for(let r of n){r.cancelled=!0,r.kind==="user"&&this.broadcastQueueRemoved(r.messageId,"abandoned");try{r.resolve({stopReason:"cancelled"})}catch{}}this.notifyChain("session.closed",{});let s=this.sessionId;this.queueWriteChain=this.queueWriteChain.catch(()=>{}).then(()=>pu(s).catch(()=>{}));for(let r of this.clients.values())r.connection.notify("hydra-acp/session/closed",{sessionId:this.sessionId}).catch(()=>{});if(this.clients.clear(),this.streamBuffer!==void 0){let r=this.streamBuffer,i=this.streamFilePath;this.streamBuffer=void 0,this.streamFilePath=void 0,r.close(),i!==void 0&&r.drainFileWrites().then(()=>wu.unlink(i).catch(()=>{}))}for(let r of this.closeHandlers)r(e)}get lastActivityAt(){return this.lastRecordedAt}scheduleIdleCheck(){if(this.closed||this.idleTimeoutMs<=0)return;let e=this.lastActivityAt+this.idleTimeoutMs;this.armIdleTimer(Math.max(0,e-Date.now()))}armIdleTimer(e){this.idleTimer&&clearTimeout(this.idleTimer),this.idleTimer=setTimeout(()=>{this.idleTimer=void 0,this.checkIdle()},e),typeof this.idleTimer.unref=="function"&&this.idleTimer.unref()}checkIdle(){if(this.closed||this.idleTimeoutMs<=0)return;if(this.turnStartedAt!==void 0||this.inFlightPermissions.size>0||this.promptQueue.length>0){this.armIdleTimer(this.idleTimeoutMs);return}let e=Date.now()-this.lastActivityAt;if(e<this.idleTimeoutMs){this.armIdleTimer(this.idleTimeoutMs-e);return}let n=this.firstPromptSeeded?{deleteRecord:!1}:{deleteRecord:!0},s=Math.round(e/1e3);this.logger?.info(`session ${this.sessionId} idle timeout fired after ${s}s (window=${Math.round(this.idleTimeoutMs/1e3)}s) \u2014 closing`),this.close(n).catch(()=>{})}cancelIdleTimer(){this.idleTimer&&(clearTimeout(this.idleTimer),this.idleTimer=void 0),this.cancelIdleEventTimer()}scheduleIdleEvent(){this.closed||this.idleEventTimeoutMs<=0||this.transformChain.length===0||(this.idleEventTimer&&clearTimeout(this.idleEventTimer),this.idleEventTimer=setTimeout(()=>{this.idleEventTimer=void 0,this.notifyChain("session.idle",{})},this.idleEventTimeoutMs),typeof this.idleEventTimer.unref=="function"&&this.idleEventTimer.unref())}cancelIdleEventTimer(){this.idleEventTimer&&(clearTimeout(this.idleEventTimer),this.idleEventTimer=void 0)}notifyChain(e,n){let s=`lifecycle:${e}`;for(let r of this.transformChain)r.intercepts.has(s)&&r.connection.notify("hydra-acp/transformer/session_event",{event:e,sessionId:this.sessionId,payload:n}).catch(()=>{})}rewriteForClient(e){if(e&&typeof e=="object"&&!Array.isArray(e)){let n=e;if(n.sessionId===this.upstreamSessionId)return{...n,sessionId:this.sessionId}}return e}recordAndBroadcast(e,n,s){let r=this.rewriteForClient(n),i=!by(e,r),o=i?Cy(e,r):r;if(i){let a={method:e,params:o,recordedAt:Date.now()};if(this.lastRecordedAt=a.recordedAt,this.appendCount+=1,this.historyStore){let d=this.historyStore;d.append(this.sessionId,a).catch(()=>{}),this.appendCount>=this.compactEvery&&(this.appendCount=0,d.compact(this.sessionId,this.historyMaxEntries).catch(()=>{}))}for(let d of this.broadcastHandlers)try{d(a)}catch{}this.scheduleIdleCheck(),this.scheduleIdleEvent()}this.updatedAt=Date.now();for(let a of this.clients.values())s&&a.clientId===s||a.connection.notify(e,o).catch(()=>{})}async requestPermissionFromClients(e){return this.handlePermissionRequest(e)}async handlePermissionRequest(e){let n=[...this.clients.values()];if(n.length===0)throw bt(new Error("no clients attached to handle permission request"),B.PermissionDenied);let s=this.rewriteForClient(e),r=Ry(s);return new Promise((i,o)=>{let a=!1,d=[],c={addClient:u};this.inFlightPermissions.add(c);let l=this.sessionId,f=p=>{a||(a=!0,this.inFlightPermissions.delete(c),p())};function u(p){if(a)return;let g=p.connection.request("session/request_permission",s);d.push({client:p}),g.then(h=>{f(()=>{let w=Ty({toolCallId:r,result:h,resolver:p});for(let v of d)v.client.clientId!==p.clientId&&v.client.connection.notify("session/update",{sessionId:l,update:w}).catch(()=>{});i(h)})}).catch(h=>{f(()=>o(h))})}for(let p of n)u(p)})}async enqueuePrompt(e){return new Promise((n,s)=>{let r={kind:"internal",messageId:Ks(),enqueuedAt:Date.now(),cancelled:!1,task:e,resolve:n,reject:s};this.promptQueue.push(r),this.drainQueue()})}async enqueueUserPrompt(e,n,s){let r=(n??{}).prompt??[],i={clientId:e.clientId};e.clientInfo?.name&&(i.name=e.clientInfo.name),e.clientInfo?.version&&(i.version=e.clientInfo.version);let o=this.parseQueuePosition(n);return new Promise((a,d)=>{let c={kind:"user",messageId:s,originator:i,clientId:e.clientId,prompt:r,enqueuedAt:Date.now(),cancelled:!1,resolve:a,reject:d},l=this.insertEntryAt(c,o);this.persistRewrite(),this.broadcastQueueAdded(c,{position:l}),this.drainQueue()})}parseQueuePosition(e){if(!e||typeof e!="object")return"tail";let n=e._meta;if(!n||typeof n!="object"||Array.isArray(n))return"tail";let s=n["hydra-acp"];if(!s||typeof s!="object"||Array.isArray(s))return"tail";let r=s.queuePosition;if(r==="head"||r==="tail")return r;if(r&&typeof r=="object"&&!Array.isArray(r)){let i=r.afterMessageId;if(typeof i=="string"&&i.length>0)return{afterMessageId:i}}return"tail"}insertEntryAt(e,n){let s=this.currentEntry?.kind==="user"&&!this.currentEntry.cancelled?1:0;if(n==="head")return this.promptQueue.unshift(e),s;if(typeof n=="object"){let r=n.afterMessageId,i=this.promptQueue.findIndex(o=>o.messageId===r);if(i>=0)return this.promptQueue.splice(i+1,0,e),s+i+1}return this.promptQueue.push(e),s+this.promptQueue.length-1}persistRewrite(){let e=[];for(let s of this.promptQueue)s.kind!=="user"||s.cancelled||e.push(this.persistedFromEntry(s));let n=this.sessionId;this.queueWriteChain=this.queueWriteChain.catch(()=>{}).then(()=>Dr(n,e).catch(()=>{}))}persistedFromEntry(e){return{messageId:e.messageId,originator:{clientInfo:{...e.originator.name!==void 0?{name:e.originator.name}:{},...e.originator.version!==void 0?{version:e.originator.version}:{}}},prompt:e.prompt,enqueuedAt:e.enqueuedAt}}async drainQueue(){if(!this.promptInFlight){this.promptInFlight=!0,await new Promise(e=>setImmediate(e));try{for(;this.promptQueue.length>0&&!this.closing;){let e=this.promptQueue.shift();if(!e)break;if(!e.cancelled){this.currentEntry=e,e.kind==="user"&&this.persistRewrite(),e.kind==="user"&&this.broadcastQueueRemoved(e.messageId,"started");try{let n=await this.runQueueEntry(e);e.resolve(n),await new Promise(s=>setImmediate(s))}catch(n){e.reject(n)}finally{this.currentEntry=void 0}}}}finally{this.promptInFlight=!1}}}async runQueueEntry(e){if(e.kind==="internal")return e.task();this.broadcastPromptReceived(e);let n=Vs(e.prompt).replace(/\s+$/,""),s=!n.includes(`
|
|
34
|
-
`
|
|
34
|
+
`},_meta:{"hydra-acp":{synthetic:!0}}}}),{stopReason:"end_turn"}}let s=this.agentAdvertisedModes;if(s.length>0&&!s.some(r=>r.id===n)){let r=s.map(i=>i.id).join(", ");throw bt(new Error(`unknown mode: ${n} (known: ${r})`),B.InvalidParams)}return await this.forwardRequest("session/set_mode",{sessionId:this.sessionId,modeId:n}),this.applyModeChange(n),{stopReason:"end_turn"}}async handleConfigCommand(e){let n=e.slice(7).trim().match(/^(\S+)(?:\s+([\s\S]*))?$/),s=n?.[1],r=n?.[2]??"";if(!s){let a=this.buildConfigOptions();if(a.length===0)return this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"agent_message_chunk",content:{type:"text",text:`
|
|
35
|
+
_(no config options advertised yet)_
|
|
36
|
+
`},_meta:{"hydra-acp":{synthetic:!0}}}}),{stopReason:"end_turn"};let d=a.map(c=>hu(c));return this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"agent_message_chunk",content:{type:"text",text:`
|
|
37
|
+
${d.join(`
|
|
38
|
+
|
|
39
|
+
`)}
|
|
40
|
+
`},_meta:{"hydra-acp":{synthetic:!0}}}}),{stopReason:"end_turn"}}let i=this.buildConfigOptions(),o=i.find(a=>a.id===s);if(!o){let a=i.map(d=>d.id).join(`
|
|
41
|
+
`);return this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"agent_message_chunk",content:{type:"text",text:`
|
|
42
|
+
"${s}" is not a known config option.
|
|
43
|
+
Available options:
|
|
44
|
+
${a}
|
|
45
|
+
`},_meta:{"hydra-acp":{synthetic:!0}}}}),{stopReason:"end_turn"}}if(!r)return this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"agent_message_chunk",content:{type:"text",text:`
|
|
46
|
+
${hu(o)}
|
|
47
|
+
`},_meta:{"hydra-acp":{synthetic:!0}}}}),{stopReason:"end_turn"};if(!o.options.some(a=>a.value===r)){let a=o.options.map(d=>d.value).join(`
|
|
48
|
+
`);return this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"agent_message_chunk",content:{type:"text",text:`
|
|
49
|
+
"${r}" is not a valid value for "${s}".
|
|
50
|
+
Valid values:
|
|
51
|
+
${a}
|
|
52
|
+
`},_meta:{"hydra-acp":{synthetic:!0}}}}),{stopReason:"end_turn"}}return await this.forwardRequest("session/set_config_option",{sessionId:this.sessionId,configId:s,value:r}),{stopReason:"end_turn"}}runTitleCommand(e){return this.enqueuePrompt(()=>this.runTitleCommandInline(e))}async runTitleCommandInline(e){return e?(this.setTitle(e),{stopReason:"end_turn"}):(this.scheduleSynopsisHook?.(),{stopReason:"end_turn"})}async runInternalPrompt(e){if(this.internalPromptCapture)throw new Error("internal prompt already in flight");let n={chunks:[]};this.internalPromptCapture=n;try{return await this.agent.connection.request("session/prompt",{sessionId:this.upstreamSessionId,prompt:[{type:"text",text:e}]}),n.chunks.join("")}finally{this.internalPromptCapture=void 0}}setAgent(e){return this.runAgentCommand(e)}runAgentCommand(e){return this.enqueuePrompt(()=>this.runAgentCommandInline(e))}async runAgentCommandInline(e){if(!e)throw bt(new Error("/hydra agent requires an agent id"),B.InvalidParams);if(e===this.agentId)throw bt(new Error(`already on agent ${e}`),B.InvalidParams);if(!this.spawnReplacementAgent)throw bt(new Error("agent switching not configured for this session"),B.InternalError);let n=this.spawnReplacementAgent,s=this.agentId,r=await this.buildSwitchTranscript(s),i=await n({agentId:e,cwd:this.cwd,agentArgs:this.agentArgs});this.accumulateAndResetCost(),this.wireAgent(i.agent);let o=this.agent;this.agent=i.agent,this.agentId=e,this.upstreamSessionId=i.upstreamSessionId,this.agentMeta=i.agentMeta,this.agentCapabilities=i.agentCapabilities,this.agentAdvertisedCommands=[],this.broadcastMergedCommands(),this.currentModel=i.initialModel,this.currentMode=i.initialMode,this.setAgentAdvertisedModels(i.initialModels??[]),this.setAgentAdvertisedModes(i.initialModes??[]),await o.kill().catch(()=>{}),r&&await this.runInternalPrompt(r).catch(()=>{}),this.broadcastAgentSwitch(s,e);let a={agentId:this.agentId,upstreamSessionId:this.upstreamSessionId};for(let d of this.agentChangeHandlers)try{d(a)}catch{}return{stopReason:"end_turn"}}async runKillCommand(){return await this.close({deleteRecord:!1}),{stopReason:"end_turn"}}runRestartCommand(){return this.enqueuePrompt(()=>this.runRestartCommandInline())}async runRestartCommandInline(){if(!this.spawnReplacementAgent)throw bt(new Error("agent restart not configured for this session"),B.InternalError);return await this.respawnAgent(),{stopReason:"end_turn"}}async forceCancel(){if(this.closed||this.closing)throw bt(new Error("session is closing"),B.SessionClosing);return this.lastCancelAt=0,this.forceCancelling=!0,await this.close({deleteRecord:!1}),{stopReason:"cancelled"}}async respawnAgent(){let e=this.spawnReplacementAgent,n=this.agentId,s=await this.buildSwitchTranscript(n),r=await e({agentId:n,cwd:this.cwd,agentArgs:this.agentArgs});this.accumulateAndResetCost(),this.wireAgent(r.agent);let i=this.agent;this.agent=r.agent,this.upstreamSessionId=r.upstreamSessionId,this.agentMeta=r.agentMeta,this.agentCapabilities=r.agentCapabilities,this.agentAdvertisedCommands=[],this.broadcastMergedCommands(),this.currentModel=r.initialModel,this.currentMode=r.initialMode,this.setAgentAdvertisedModels(r.initialModels??[]),this.setAgentAdvertisedModes(r.initialModes??[]),await i.kill().catch(()=>{}),s&&await this.runInternalPrompt(s).catch(()=>{}),this.broadcastAgentSwitch(n,n);let o={agentId:n,upstreamSessionId:this.upstreamSessionId};for(let a of this.agentChangeHandlers)try{a(o)}catch{}}async buildSwitchTranscript(e,n){let s=[],r=await this.getHistorySnapshot();for(let c of r){if(c.method!=="session/update")continue;let f=(c.params??{}).update;if(!f||f._meta?.["hydra-acp"]?.synthetic)continue;let p=f.sessionUpdate;if(p==="prompt_received"){let g=Ys(f.prompt);g&&s.push({speaker:"user",text:g})}else if(p==="agent_message_chunk"){let h=f.content?.text;h&&s.push({speaker:`agent: ${e}`,text:h})}else if(p==="tool_call"||p==="tool_call_update"){let g=f.status,h=f.title;(g==="completed"||g==="failed")&&s.push({speaker:"tool",text:`${h??"?"} ${g}`})}}if(s.length===0)return"";let i=[],o;for(let c of s)o&&o.speaker===c.speaker?o.text+=c.text:(o&&i.push(`<${o.speaker}>: ${o.text.trim()}`),o={speaker:c.speaker,text:c.text});o&&i.push(`<${o.speaker}>: ${o.text.trim()}`);let a=n?.intro??`You are taking over this conversation from ${e}. Below is the transcript so far.`,d=n?.followup??`Each line is prefixed with its speaker. Continue from where ${e} left off, responding to the user's most recent message.`;return[a,d,"","--- begin transcript ---",...i,"--- end transcript ---"].join(`
|
|
53
|
+
`)}async seedFromImport(){await this.enqueuePrompt(async()=>{let e=await this.buildSwitchTranscript(this.agentId,{intro:"You are continuing a conversation that was imported from another hydra. Below is the transcript so far.",followup:"Each line is prefixed with its speaker. Treat this as context for the next user message; do not re-respond to earlier turns."});e&&await this.runInternalPrompt(e).catch(()=>{})})}broadcastAgentSwitch(e,n){this.recordAndBroadcast("session/update",{sessionId:this.sessionId,update:{sessionUpdate:"session_info_update",_meta:{"hydra-acp":{synthetic:!0,agentId:n}}}}),this.broadcastConfigOptions()}hasStreamBuffer(){return this.streamBuffer!==void 0}get streamPath(){return this.streamFilePath}openStream(e){if(this.streamBuffer!==void 0)throw new Error(`stream buffer already open for session ${this.sessionId}`);let s=(e.mode??"memory")==="file"&&e.filePathFor!==void 0?e.filePathFor(this.sessionId):void 0,r={};e.capacityBytes!==void 0&&(r.capacityBytes=e.capacityBytes),s!==void 0&&(r.filePath=s),e.fileCapBytes!==void 0&&(r.fileCapBytes=e.fileCapBytes),r.onFileCapReached=()=>{this.recordAndBroadcast("session/update",{sessionId:this.upstreamSessionId,update:{sessionUpdate:"stream_truncated",...s!==void 0?{filePath:s}:{},fileCapBytes:e.fileCapBytes}})};let i=new Qi(r);this.streamBuffer=i,this.streamFilePath=s;let o={capacityBytes:i.capacity};return s!==void 0&&(o.filePath=s),e.fileCapBytes!==void 0&&(o.fileCapBytes=e.fileCapBytes),o}streamWrite(e,n){let s=this.requireStreamBuffer();if(e.length>0){let r=Buffer.from(e,"base64");s.append(r)}return n===!0&&s.close(),{writeCursor:s.writeCursorPos}}async streamRead(e,n,s){let r=this.requireStreamBuffer(),i=Math.max(0,Math.min(n??Js,Js)),o=r.read(e,i);if(o.bytes.length===0&&o.eof!==!0&&s!==void 0&&s>0){let d=await r.waitForData(o.nextCursor,s);(d==="data"||d==="eof")&&(o=r.read(o.nextCursor,i))}let a={bytes:o.bytes.toString("base64"),nextCursor:o.nextCursor};return o.gap!==void 0&&(a.gap=o.gap),o.eof===!0&&(a.eof=!0),a}streamTail(e){let s=this.requireStreamBuffer().tail(e);return{bytes:s.bytes.toString("base64"),startCursor:s.startCursor,endCursor:s.endCursor,truncated:s.truncated}}streamHead(e){let s=this.requireStreamBuffer().head(e);return{bytes:s.bytes.toString("base64"),startCursor:s.startCursor,endCursor:s.endCursor,truncated:s.truncated}}async streamWaitFor(e,n){return this.requireStreamBuffer().waitForData(e,n)}streamGrep(e){return this.requireStreamBuffer().grep(e)}streamInfo(){let e=this.requireStreamBuffer();return{writeCursor:e.writeCursorPos,oldestAvailable:e.oldestAvailable,capacity:e.capacity,closed:e.isClosed}}requireStreamBuffer(){if(this.streamBuffer===void 0){let e=new Error(`session ${this.sessionId} has no stream buffer; POST /v1/sessions/:id/stdin/open first`);throw e.code=B.StreamNotEnabled,e}return this.streamBuffer}markClosed(e){if(this.closed)return;this.closing=!0,this.closed=!0,this.cancelIdleTimer(),this.extensionCommandsUnsub&&(this.extensionCommandsUnsub(),this.extensionCommandsUnsub=void 0);for(let r of[...this.inFlightExtensionDispatches.keys()])this.cancelExtensionDispatch(r,"abandoned");this.currentEntry?.kind==="user"&&!this.recentlyTerminal.has(this.currentEntry.messageId)&&this.broadcastTurnComplete(this.currentEntry.clientId,{stopReason:"interrupted"},this.currentEntry.messageId,this.currentEntry.wasAmend),this.currentEntry=void 0;let n=this.promptQueue;this.promptQueue=[];for(let r of n){r.cancelled=!0,r.kind==="user"&&this.broadcastQueueRemoved(r.messageId,"abandoned");try{r.resolve({stopReason:"cancelled"})}catch{}}this.notifyChain("session.closed",{});let s=this.sessionId;this.queueWriteChain=this.queueWriteChain.catch(()=>{}).then(()=>pu(s).catch(()=>{}));for(let r of this.clients.values())r.connection.notify("hydra-acp/session/closed",{sessionId:this.sessionId}).catch(()=>{});if(this.clients.clear(),this.streamBuffer!==void 0){let r=this.streamBuffer,i=this.streamFilePath;this.streamBuffer=void 0,this.streamFilePath=void 0,r.close(),i!==void 0&&r.drainFileWrites().then(()=>bu.unlink(i).catch(()=>{}))}for(let r of this.closeHandlers)r(e)}get lastActivityAt(){return this.lastRecordedAt}scheduleIdleCheck(){if(this.closed||this.idleTimeoutMs<=0)return;let e=this.lastActivityAt+this.idleTimeoutMs;this.armIdleTimer(Math.max(0,e-Date.now()))}armIdleTimer(e){this.idleTimer&&clearTimeout(this.idleTimer),this.idleTimer=setTimeout(()=>{this.idleTimer=void 0,this.checkIdle()},e),typeof this.idleTimer.unref=="function"&&this.idleTimer.unref()}checkIdle(){if(this.closed||this.idleTimeoutMs<=0)return;if(this.turnStartedAt!==void 0||this.inFlightPermissions.size>0||this.promptQueue.length>0){this.armIdleTimer(this.idleTimeoutMs);return}let e=Date.now()-this.lastActivityAt;if(e<this.idleTimeoutMs){this.armIdleTimer(this.idleTimeoutMs-e);return}let n=this.firstPromptSeeded?{deleteRecord:!1}:{deleteRecord:!0},s=Math.round(e/1e3);this.logger?.info(`session ${this.sessionId} idle timeout fired after ${s}s (window=${Math.round(this.idleTimeoutMs/1e3)}s) \u2014 closing`),this.close(n).catch(()=>{})}cancelIdleTimer(){this.idleTimer&&(clearTimeout(this.idleTimer),this.idleTimer=void 0),this.cancelIdleEventTimer()}scheduleIdleEvent(){this.closed||this.idleEventTimeoutMs<=0||this.transformChain.length===0||(this.idleEventTimer&&clearTimeout(this.idleEventTimer),this.idleEventTimer=setTimeout(()=>{this.idleEventTimer=void 0,this.notifyChain("session.idle",{})},this.idleEventTimeoutMs),typeof this.idleEventTimer.unref=="function"&&this.idleEventTimer.unref())}cancelIdleEventTimer(){this.idleEventTimer&&(clearTimeout(this.idleEventTimer),this.idleEventTimer=void 0)}notifyChain(e,n){let s=`lifecycle:${e}`;for(let r of this.transformChain)r.intercepts.has(s)&&r.connection.notify("hydra-acp/transformer/session_event",{event:e,sessionId:this.sessionId,payload:n}).catch(()=>{})}rewriteForClient(e){if(e&&typeof e=="object"&&!Array.isArray(e)){let n=e;if(n.sessionId===this.upstreamSessionId)return{...n,sessionId:this.sessionId}}return e}recordAndBroadcast(e,n,s){let r=this.rewriteForClient(n),i=!vy(e,r),o=i?Ry(e,r):r;if(i){let a={method:e,params:o,recordedAt:Date.now()};if(this.lastRecordedAt=a.recordedAt,this.appendCount+=1,this.historyStore){let d=this.historyStore;d.append(this.sessionId,a).catch(()=>{}),this.appendCount>=this.compactEvery&&(this.appendCount=0,d.compact(this.sessionId,this.historyMaxEntries).catch(()=>{}))}for(let d of this.broadcastHandlers)try{d(a)}catch{}this.scheduleIdleCheck(),this.scheduleIdleEvent()}this.updatedAt=Date.now();for(let a of this.clients.values())s&&a.clientId===s||a.connection.notify(e,o).catch(()=>{})}async requestPermissionFromClients(e){return this.handlePermissionRequest(e)}async handlePermissionRequest(e){let n=[...this.clients.values()];if(n.length===0)throw bt(new Error("no clients attached to handle permission request"),B.PermissionDenied);let s=this.rewriteForClient(e),r=Ty(s);return new Promise((i,o)=>{let a=!1,d=[],c={addClient:u};this.inFlightPermissions.add(c);let l=this.sessionId,f=p=>{a||(a=!0,this.inFlightPermissions.delete(c),p())};function u(p){if(a)return;let g=p.connection.request("session/request_permission",s);d.push({client:p}),g.then(h=>{f(()=>{let w=Ey({toolCallId:r,result:h,resolver:p});for(let v of d)v.client.clientId!==p.clientId&&v.client.connection.notify("session/update",{sessionId:l,update:w}).catch(()=>{});i(h)})}).catch(h=>{f(()=>o(h))})}for(let p of n)u(p)})}async enqueuePrompt(e){return new Promise((n,s)=>{let r={kind:"internal",messageId:Vs(),enqueuedAt:Date.now(),cancelled:!1,task:e,resolve:n,reject:s};this.promptQueue.push(r),this.drainQueue()})}async enqueueUserPrompt(e,n,s){let r=(n??{}).prompt??[],i={clientId:e.clientId};e.clientInfo?.name&&(i.name=e.clientInfo.name),e.clientInfo?.version&&(i.version=e.clientInfo.version);let o=this.parseQueuePosition(n);return new Promise((a,d)=>{let c={kind:"user",messageId:s,originator:i,clientId:e.clientId,prompt:r,enqueuedAt:Date.now(),cancelled:!1,resolve:a,reject:d},l=this.insertEntryAt(c,o);this.persistRewrite(),this.broadcastQueueAdded(c,{position:l}),this.drainQueue()})}parseQueuePosition(e){if(!e||typeof e!="object")return"tail";let n=e._meta;if(!n||typeof n!="object"||Array.isArray(n))return"tail";let s=n["hydra-acp"];if(!s||typeof s!="object"||Array.isArray(s))return"tail";let r=s.queuePosition;if(r==="head"||r==="tail")return r;if(r&&typeof r=="object"&&!Array.isArray(r)){let i=r.afterMessageId;if(typeof i=="string"&&i.length>0)return{afterMessageId:i}}return"tail"}insertEntryAt(e,n){let s=this.currentEntry?.kind==="user"&&!this.currentEntry.cancelled?1:0;if(n==="head")return this.promptQueue.unshift(e),s;if(typeof n=="object"){let r=n.afterMessageId,i=this.promptQueue.findIndex(o=>o.messageId===r);if(i>=0)return this.promptQueue.splice(i+1,0,e),s+i+1}return this.promptQueue.push(e),s+this.promptQueue.length-1}persistRewrite(){let e=[];for(let s of this.promptQueue)s.kind!=="user"||s.cancelled||e.push(this.persistedFromEntry(s));let n=this.sessionId;this.queueWriteChain=this.queueWriteChain.catch(()=>{}).then(()=>Dr(n,e).catch(()=>{}))}persistedFromEntry(e){return{messageId:e.messageId,originator:{clientInfo:{...e.originator.name!==void 0?{name:e.originator.name}:{},...e.originator.version!==void 0?{version:e.originator.version}:{}}},prompt:e.prompt,enqueuedAt:e.enqueuedAt}}async drainQueue(){if(!this.promptInFlight){this.promptInFlight=!0,await new Promise(e=>setImmediate(e));try{for(;this.promptQueue.length>0&&!this.closing;){let e=this.promptQueue.shift();if(!e)break;if(!e.cancelled){this.currentEntry=e,e.kind==="user"&&this.persistRewrite(),e.kind==="user"&&this.broadcastQueueRemoved(e.messageId,"started");try{let n=await this.runQueueEntry(e);e.resolve(n),await new Promise(s=>setImmediate(s))}catch(n){e.reject(n)}finally{this.currentEntry=void 0}}}}finally{this.promptInFlight=!1}}}async runQueueEntry(e){if(e.kind==="internal")return e.task();this.broadcastPromptReceived(e);let n=Ys(e.prompt).replace(/\s+$/,""),s=!n.includes(`
|
|
54
|
+
`)&&n.startsWith("/")?n.split(/\s+/)[0]:"";if(s==="/model"||s==="/mode"||s==="/sessions"||s==="/help"||s==="/hydra"){let i;return s==="/sessions"?i=await this.handleSessionsCommand():s==="/help"?i=await this.handleHelpCommand():s==="/mode"?i=await this.handleModeCommand(n):s==="/model"?i=await this.handleModelCommand(n):i=await this.handleSlashCommand(n,e.messageId),this.closed||this.broadcastTurnComplete(e.clientId,i,e.messageId,e.wasAmend),this.clearAmendIfMatches(e.messageId),i}let r;try{r=await this.agent.connection.request("session/prompt",{sessionId:this.upstreamSessionId,prompt:e.prompt})}catch(i){if(this.forceCancelling)return this.clearAmendIfMatches(e.messageId),{stopReason:"cancelled"};throw this.closed||this.broadcastTurnComplete(e.clientId,{stopReason:"error"},e.messageId,e.wasAmend),this.clearAmendIfMatches(e.messageId),i}return this.closed||this.broadcastTurnComplete(e.clientId,r,e.messageId,e.wasAmend),this.clearAmendIfMatches(e.messageId),r}clearAmendIfMatches(e){this.amendInProgress?.cancelledMessageId===e&&(this.amendInProgress=void 0)}};by=new Set(["session_info_update","current_model_update","current_mode_update","available_commands_update","available_modes_update","usage_update","config_option_update"])});import{z as Ot}from"zod";function Iu(t){let e=t.trim();if(e.length===0)return;let n=vu(e);if(n===void 0){let i=e.indexOf("{"),o=e.lastIndexOf("}");if(i<0||o<=i||(n=vu(e.slice(i,o+1)),n===void 0))return}if(n===null||typeof n!="object")return;let s=n,r={};if(typeof s.title=="string"){let i=s.title.trim();i.length>0&&(r.title=i.slice(0,$y))}if(s.synopsis!==void 0&&s.synopsis!==null){let i=Hr.safeParse(s.synopsis);i.success&&_y(i.data)&&(r.synopsis=i.data)}if(!(r.title===void 0&&r.synopsis===void 0))return r}function vu(t){try{return JSON.parse(t)}catch{return}}function _y(t){return t.goal!==void 0&&t.goal.trim().length>0||t.outcome!==void 0&&t.outcome.trim().length>0||t.files_touched!==void 0&&t.files_touched.length>0||t.tools_used!==void 0&&t.tools_used.length>0||t.rejected_approaches!==void 0&&t.rejected_approaches.length>0||t.open_threads!==void 0&&t.open_threads.length>0}var Hr,$y,Za,Zi=V(()=>{"use strict";Hr=Ot.object({goal:Ot.string().optional(),outcome:Ot.string().optional(),files_touched:Ot.array(Ot.string()).optional(),tools_used:Ot.array(Ot.string()).optional(),rejected_approaches:Ot.array(Ot.string()).optional(),open_threads:Ot.array(Ot.string()).optional()}),$y=200,Za=`Reply with ONLY a JSON object with exactly these keys, no prose, no markdown, no code fences:
|
|
35
55
|
{
|
|
36
56
|
"title": "short summary, max 80 chars",
|
|
37
57
|
"synopsis": {
|
|
@@ -41,61 +61,61 @@ ${o}
|
|
|
41
61
|
"open_threads": ["work started but not finished"]
|
|
42
62
|
}
|
|
43
63
|
}
|
|
44
|
-
Use empty arrays/strings where a field doesn't apply.`});import*as Gs from"fs/promises";import*as
|
|
45
|
-
`))if(n.length!==0)try{let s=JSON.parse(n);typeof s=="string"&&e.push(s)}catch{}return e}function Jr(t,e,n=
|
|
64
|
+
Use empty arrays/strings where a field doesn't apply.`});import*as Gs from"fs/promises";import*as ZA from"path";import{customAlphabet as Fy}from"nanoid";import{z as ne}from"zod";function Ur(){return`${By}${Ly()}`}function Hy(t){if(!ed.test(t))throw new Error(`unsafe session id: ${t}`)}function id(t){let e=new Date().toISOString();return{sessionId:t.sessionId,lineageId:t.lineageId,upstreamSessionId:t.upstreamSessionId,importedFromSessionId:t.importedFromSessionId,importedFromUpstreamSessionId:t.importedFromUpstreamSessionId,importedFromMachine:t.importedFromMachine,agentId:t.agentId,cwd:t.cwd,title:t.title,synopsis:t.synopsis,summarizedThroughEntry:t.summarizedThroughEntry,agentArgs:t.agentArgs,currentModel:t.currentModel,currentMode:t.currentMode,currentUsage:t.currentUsage,agentCommands:t.agentCommands,agentModes:t.agentModes,agentModels:t.agentModels,pendingHistorySync:t.pendingHistorySync,parentSessionId:t.parentSessionId,forkedFromSessionId:t.forkedFromSessionId,forkedFromMessageId:t.forkedFromMessageId,originatingClient:t.originatingClient,interactive:t.interactive,priority:t.priority,createdAt:t.createdAt??e,updatedAt:t.updatedAt??e}}var Oy,Ly,By,td,nd,Ny,sd,rd,Dy,ed,eo,od=V(()=>{"use strict";ue();os();Zi();Oy="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",Ly=Fy(Oy,16),By="hydra_lineage_";td=ne.object({name:ne.string(),description:ne.string().optional()}),nd=ne.object({id:ne.string(),name:ne.string().optional(),description:ne.string().optional()}),Ny=ne.object({modelId:ne.string(),name:ne.string().optional(),description:ne.string().optional()}),sd=ne.object({used:ne.number().optional(),size:ne.number().optional(),costAmount:ne.number().optional(),costCurrency:ne.string().optional(),cumulativeCost:ne.number().optional()}),rd=ne.object({name:ne.string(),version:ne.string().optional()}),Dy=ne.object({version:ne.literal(1),sessionId:ne.string(),lineageId:ne.string().optional(),upstreamSessionId:ne.string(),importedFromSessionId:ne.string().optional(),importedFromUpstreamSessionId:ne.string().optional(),importedFromMachine:ne.string().optional(),agentId:ne.string(),cwd:ne.string(),title:ne.string().optional(),synopsis:Hr.optional(),summarizedThroughEntry:ne.number().int().nonnegative().optional(),agentArgs:ne.array(ne.string()).optional(),currentModel:ne.string().optional(),currentMode:ne.string().optional(),currentUsage:sd.optional(),agentCommands:ne.array(td).optional(),agentModes:ne.array(nd).optional(),agentModels:ne.array(Ny).optional(),pendingHistorySync:ne.boolean().optional(),parentSessionId:ne.string().optional(),forkedFromSessionId:ne.string().optional(),forkedFromMessageId:ne.string().optional(),originatingClient:rd.optional(),interactive:ne.boolean().optional(),priority:ne.number().int().nonnegative().optional(),createdAt:ne.string(),updatedAt:ne.string()}),ed=/^[A-Za-z0-9_-]+$/;eo=class{async write(e){Hy(e.sessionId);let n={version:1,...e};await ht(P.sessionFile(e.sessionId),n,{mode:384})}async read(e){if(!ed.test(e))return;let n=await At(P.sessionFile(e));if(n!==void 0)try{return Dy.parse(n)}catch{return}}async delete(e){if(ed.test(e)){try{await Gs.unlink(P.sessionFile(e))}catch(n){if(n.code!=="ENOENT")throw n}try{await Gs.rmdir(P.sessionDir(e))}catch(n){let s=n;if(s.code!=="ENOENT"&&s.code!=="ENOTEMPTY")throw n}}}async findByLineageId(e){if(e.length===0)return;let n=await this.list().catch(()=>[]);for(let s of n)if(s.lineageId===e)return s}async list(){let e;try{e=await Gs.readdir(P.sessionsDir())}catch(r){if(r.code==="ENOENT")return[];throw r}let n=await Promise.all(e.map(r=>this.read(r).catch(()=>{}))),s=[];for(let r of n)r&&s.push(r);return s}}});import{fileURLToPath as jy}from"url";import*as jr from"path";import*as no from"fs";function qy(){try{let t=jr.dirname(jy(import.meta.url));for(let e=0;e<8;e+=1){let n=jr.join(t,"package.json");if(no.existsSync(n)){let r=JSON.parse(no.readFileSync(n,"utf8"));if(typeof r.version=="string"&&r.version.length>0&&(typeof r.name!="string"||r.name.includes("hydra-acp")))return r.version}let s=jr.dirname(t);if(s===t)break;t=s}}catch{}return"0.0.0"}var me,cs,Lt=V(()=>{"use strict";me=qy(),cs="hydra-acp-cat"});function ad(t){let e=new Map;for(let n of $u(t).values())e.set(n.toolName,(e.get(n.toolName)??0)+1);return[...e.entries()].map(([n,s])=>({name:n,count:s})).sort((n,s)=>s.count-n.count||n.name.localeCompare(s.name))}function Eu(t){return ad(t).map(e=>e.name)}function dd(t){let e=new Map;for(let n of $u(t).values())for(let s of n.paths){let r=e.get(s);r===void 0&&(r=new Map,e.set(s,r)),r.set(n.toolName,(r.get(n.toolName)??0)+1)}return[...e.entries()].map(([n,s])=>{let r=[...s.entries()].map(([o,a])=>({name:o,count:a})).sort((o,a)=>a.count-o.count||o.name.localeCompare(a.name)),i=r.reduce((o,a)=>o+a.count,0);return{path:n,count:i,byTool:r}}).sort((n,s)=>s.count-n.count||n.path.localeCompare(s.path))}function Pu(t){return dd(t).map(e=>e.path)}function Mu(t){let e=0;for(let n of t)n.params?.update?.sessionUpdate==="prompt_received"&&(e+=1);return e}function $u(t){let e=new Map,n=0;for(let s of t){let i=s.params?.update;if(!i)continue;let o=i.sessionUpdate;if(o!=="tool_call"&&o!=="tool_call_update")continue;if(o==="tool_call"){let d=typeof i.toolCallId=="string"&&i.toolCallId.length>0?i.toolCallId:`__synth_${n++}`,c=e.get(d);c===void 0?(c={toolName:Ru(i),paths:new Set},e.set(d,c)):c.toolName=Ru(i);for(let l of Tu(i.rawInput,i.locations))c.paths.add(l);continue}if(typeof i.toolCallId!="string"||i.toolCallId.length===0)continue;let a=e.get(i.toolCallId);if(a!==void 0)for(let d of Tu(i.rawInput,i.locations))a.paths.add(d)}return e}function Ru(t){return typeof t.name=="string"&&t.name.length>0?t.name:typeof t.title=="string"&&t.title.length>0?t.title:"(unnamed)"}function Tu(t,e){let n=new Set;if(t&&typeof t=="object"&&!Array.isArray(t)){let s=t;typeof s.file_path=="string"?n.add(s.file_path):typeof s.path=="string"&&n.add(s.path);let r=s.edits;if(Array.isArray(r)){for(let i of r)if(i&&typeof i=="object"){let o=i.file_path;typeof o=="string"&&n.add(o)}}}if(Array.isArray(e)){for(let s of e)if(s&&typeof s=="object"){let r=s.path;typeof r=="string"&&n.add(r)}}return n}var cd=V(()=>{"use strict"});import{promises as Wr}from"fs";import*as hd from"path";async function zr(t){let e;try{e=await Wr.readFile(t,"utf8")}catch(n){if(n.code==="ENOENT")return[];throw n}return lw(e)}function lw(t){let e=[];for(let n of t.split(`
|
|
65
|
+
`))if(n.length!==0)try{let s=JSON.parse(n);typeof s=="string"&&e.push(s)}catch{}return e}function Jr(t,e,n=Hu){let s=e.replace(/\n+$/,"");if(s.length===0||t.length>0&&t[t.length-1]===s)return t;let r=t.concat(s);return r.length>n?r.slice(r.length-n):r}async function ls(t,e){await Wr.mkdir(hd.dirname(t),{recursive:!0});let n=e.map(s=>JSON.stringify(s));await Wr.writeFile(t,n.length>0?n.join(`
|
|
46
66
|
`)+`
|
|
47
|
-
`:"")}async function
|
|
48
|
-
`,{encoding:"utf8"}))}function io(t,e){if(e.length===0)return[...t];let n=new Set(e);return[...t.filter(r=>!n.has(r)),...e]}function gd(t,e,n=Du){if(e.length===0)return t;let s=new Set(t),r=t;for(let i of e){let o=i.replace(/\n+$/,"");o.length!==0&&(s.has(o)||(s.add(o),r=Jr(r,o,n)))}return r}var Du,oo=V(()=>{"use strict";Du=500});import{z as ye}from"zod";function Kr(t){let e={version:1,exportedAt:new Date().toISOString(),exportedFrom:{hydraVersion:t.hydraVersion,machine:t.machine,...t.hydraHost!==void 0&&t.hydraHost.length>0?{hydraHost:t.hydraHost}:{}},session:{sessionId:t.record.sessionId,lineageId:t.record.lineageId,...t.record.upstreamSessionId?{upstreamSessionId:t.record.upstreamSessionId}:{},agentId:t.record.agentId,cwd:t.record.cwd,...t.record.title!==void 0?{title:t.record.title}:{},...t.record.synopsis!==void 0?{synopsis:t.record.synopsis}:{},...t.record.summarizedThroughEntry!==void 0?{summarizedThroughEntry:t.record.summarizedThroughEntry}:{},...t.record.currentModel!==void 0?{currentModel:t.record.currentModel}:{},...t.record.currentMode!==void 0?{currentMode:t.record.currentMode}:{},...t.record.currentUsage!==void 0?{currentUsage:t.record.currentUsage}:{},...t.record.agentCommands!==void 0?{agentCommands:t.record.agentCommands}:{},...t.record.agentModes!==void 0?{agentModes:t.record.agentModes}:{},...t.record.interactive!==void 0?{interactive:t.record.interactive}:{},...t.record.originatingClient!==void 0?{originatingClient:t.record.originatingClient}:{},...t.record.priority!==void 0&&t.record.priority>0?{priority:t.record.priority}:{},createdAt:t.record.createdAt,updatedAt:t.record.updatedAt},history:t.history};return t.promptHistory!==void 0&&(e.promptHistory=t.promptHistory),t.toolBlobs!==void 0&&Object.keys(t.toolBlobs).length>0&&(e.toolBlobs=t.toolBlobs),e}function Bt(t){return fw.parse(t)}var lw,uw,fw,ls=V(()=>{"use strict";od();Zi();lw=ye.object({method:ye.string(),params:ye.unknown(),recordedAt:ye.number()}),uw=ye.object({sessionId:ye.string(),lineageId:ye.string(),upstreamSessionId:ye.string().optional(),agentId:ye.string(),cwd:ye.string(),title:ye.string().optional(),synopsis:Hr.optional(),summarizedThroughEntry:ye.number().int().nonnegative().optional(),currentModel:ye.string().optional(),currentMode:ye.string().optional(),currentUsage:sd.optional(),agentCommands:ye.array(td).optional(),agentModes:ye.array(nd).optional(),interactive:ye.boolean().optional(),originatingClient:rd.optional(),priority:ye.number().int().nonnegative().optional(),createdAt:ye.string(),updatedAt:ye.string()}),fw=ye.object({version:ye.literal(1),exportedAt:ye.string(),exportedFrom:ye.object({hydraVersion:ye.string(),machine:ye.string(),hydraHost:ye.string().optional()}),session:uw,history:ye.array(lw),promptHistory:ye.array(ye.string()).optional(),toolBlobs:ye.record(ye.string()).optional()})});import{createHash as Cw}from"crypto";function Sd(t){if(Array.isArray(t))return t.map(Sd);if(t!==null&&typeof t=="object"){let e={};for(let n of Object.keys(t).sort())e[n]=Sd(t[n]);return e}return t}function er(t){let e=JSON.stringify(Sd(t));return Cw("sha256").update(e).digest("hex").slice(0,16)}var wo=V(()=>{"use strict";Ne()});function Xr(t){if(!t||typeof t!="object")return;let e=t;return typeof e.workerTaskId=="string"?e.workerTaskId:void 0}var lf=V(()=>{"use strict"});import{posix as Nw}from"path";import Dw from"strip-ansi";function ct(t){return Dw(t).replace(Hw,"")}function ke(t){return ct(t).replace(/[\n\t]+/g," ").replace(/ +/g," ").trim()}function fs(t,e={}){if(!t||typeof t!="object")return null;let n=t,s=n.sessionUpdate??n.kind;if(typeof s!="string")return null;switch(s){case"agent_message_chunk":return Jw(n);case"agent_thought_chunk":case"agent_thought":return Kw(n);case"user_message_chunk":return Vw(n);case"prompt_received":return Yw(n);case"tool_call":return Qw(n,e);case"tool_call_update":return tb(n,e);case"plan":return rb(n);case"current_mode_update":return ib(n);case"current_model_update":return ob(n);case"turn_complete":return ab(n);case"usage_update":return zw(n);case"available_commands_update":return qw(n);case"available_modes_update":return Ww(n);case"session_info_update":return jw(n);case"config_option_update":return Uw(n);default:return{kind:"unknown",sessionUpdate:s,raw:t}}}function Uw(t){let e=t.configOptions;if(!Array.isArray(e))return null;let n=[];for(let s of e){if(!s||typeof s!="object")continue;let r=s;if(typeof r.id!="string"||typeof r.currentValue!="string"||!Array.isArray(r.options))continue;let i=[];for(let o of r.options){if(!o||typeof o!="object")continue;let a=o;typeof a.value=="string"&&i.push({value:a.value,name:typeof a.name=="string"?a.name:a.value,...typeof a.description=="string"?{description:a.description}:{}})}n.push({id:r.id,name:typeof r.name=="string"?r.name:r.id,type:"select",currentValue:r.currentValue,options:i,...typeof r.category=="string"?{category:r.category}:{}})}return{kind:"config-options",options:n}}function jw(t){let e=_e(t,"title"),n=e!==void 0?ke(e):void 0,s=t._meta,r;if(s&&typeof s=="object"&&!Array.isArray(s)){let o=s["hydra-acp"];if(o&&typeof o=="object"&&!Array.isArray(o)){let a=o.agentId;typeof a=="string"&&(r=a)}}if(n===void 0&&r===void 0)return null;let i={kind:"session-info"};return n!==void 0&&(i.title=n),r!==void 0&&(i.agentId=r),i}function Ao(t){if(!Array.isArray(t))return[];let e=[];for(let n of t){if(!n||typeof n!="object")continue;let s=n;if(typeof s.name!="string"||s.name.length===0)continue;let r=s.name.startsWith("/")?s.name:`/${s.name}`,i={name:ke(r)};typeof s.description=="string"&&(i.description=ke(s.description)),e.push(i)}return e}function qw(t){let e=t.availableCommands??t.commands;return Array.isArray(e)?{kind:"available-commands",commands:Ao(e)}:null}function Ww(t){let e=t.availableModes;if(!Array.isArray(e))return null;let n=[];for(let s of e){if(!s||typeof s!="object")continue;let r=s;if(typeof r.id!="string"||r.id.length===0)continue;let i={id:ke(r.id)};typeof r.name=="string"&&(i.name=ke(r.name)),typeof r.description=="string"&&(i.description=ke(r.description)),n.push(i)}return{kind:"available-modes",modes:n}}function zw(t){let e={kind:"usage-update"};if(typeof t.used=="number"&&(e.used=t.used),typeof t.size=="number"&&(e.size=t.size),t.cost&&typeof t.cost=="object"){let n=t.cost;typeof n.amount=="number"&&(e.costAmount=n.amount),typeof n.currency=="string"&&(e.costCurrency=n.currency)}return e}function Jw(t){let e=Zr(t.content);return e===null?null:{kind:"agent-text",text:e,workerTaskId:Xr(t)}}function Kw(t){let e=typeof t.text=="string"?ct(t.text):Zr(t.content);return e===null?null:{kind:"agent-thought",text:e,workerTaskId:Xr(t)}}function Vw(t){let e=t._meta;if(e&&typeof e=="object"&&!Array.isArray(e)){let s=e["hydra-acp"];if(s&&typeof s=="object"&&!Array.isArray(s)&&s.compatFor==="prompt_received")return null}let n=Zr(t.content);return n===null?null:{kind:"user-text",text:n}}function Yw(t){let e=db(t.prompt);return e===null?null:{kind:"user-text",text:e}}function pf(t){return t?t.toLowerCase().replace(/[_\s-]/g,"")==="exitplanmode":!1}function uf(t){if(typeof t=="string")return{text:t};if(t&&typeof t=="object"&&!Array.isArray(t)){let e=t;if(typeof e.__hydraBlob=="string")return{ref:{hash:e.__hydraBlob,bytes:typeof e.bytes=="number"?e.bytes:0}}}}function Co(t){let e=t.content;if(Array.isArray(e))for(let s of e){if(!s||typeof s!="object")continue;let r=s;if(r.type!=="diff")continue;let i=uf(r.oldText),o=uf(r.newText);if(i===void 0&&o===void 0)continue;let a=typeof r.path=="string"?r.path:void 0;return{...a!==void 0?{path:a}:{},oldText:i?.text??"",newText:o?.text??"",...i?.ref?{oldRef:i.ref}:{},...o?.ref?{newRef:o.ref}:{}}}let n=t.rawInput;if(n&&typeof n=="object"&&!Array.isArray(n)){let s=n,r=typeof s.file_path=="string"?s.file_path:typeof s.path=="string"?s.path:void 0;if(typeof s.old_string=="string"&&typeof s.new_string=="string")return{...r!==void 0?{path:r}:{},oldText:s.old_string,newText:s.new_string};if(typeof s.content=="string")return{...r!==void 0?{path:r}:{},oldText:"",newText:s.content}}return null}function mf(t){let e=t.rawInput;if(!e||typeof e!="object"||Array.isArray(e))return null;let n=e.plan;return typeof n!="string"||n.length===0?null:ct(n)}function Qw(t,e={}){let n=_e(t,"toolCallId")??_e(t,"id");if(!n)return null;let s=_e(t,"title")??_e(t,"name")??_e(t,"label")??"tool call",r=_e(t,"name")??_e(t,"title");if(pf(r)){let u=mf(t);if(u!==null){let p=_e(t,"status"),g={kind:"exit-plan-mode",toolCallId:n,plan:u};return p!==void 0&&(g.status=p),g}}let i=gf(ke(s),t,e),o=_e(t,"status"),a=_e(t,"kind"),d={kind:"tool-call",toolCallId:n,title:i};o!==void 0&&(d.status=o),a!==void 0&&(d.rawKind=a);let c=Co(t);c!==null&&(d.editDiff=c);let l=hf(t);l!==void 0&&(d.detail=l);let f=Xr(t);return f!==void 0&&(d.workerTaskId=f),d}function hf(t){let e=t.rawInput;if(!e||typeof e!="object"||Array.isArray(e))return;let n=e;if(typeof n.command=="string"&&n.command.trim().length>0){let i=ke(n.command).trim().replace(/^cd\s+\S+\s+&&\s+/,"");return Zw(i,ff)}let s=typeof n.file_path=="string"?n.file_path:typeof n.filePath=="string"?n.filePath:typeof n.path=="string"?n.path:void 0;if(s!==void 0&&s.length>0)return eb(Be(ke(s)),ff)}function Xw(t){for(let e of Gw)if(t.startsWith(e))return!0;return!1}function gf(t,e,n={}){if(t.length===0)return t;if(t.startsWith("/"))return Be(t);if(t.startsWith("~")||!t.includes("/")||/\s/.test(t))return t;let s=e.rawInput;if(s&&typeof s=="object"&&!Array.isArray(s)){let r=s,i=[r.file_path,r.filePath,r.path];for(let o of i)if(!(typeof o!="string"||o.length===0)&&(o===`/${t}`||o.endsWith(`/${t}`)||o===t))return Be(o)}return Xw(t)?Be(`/${t}`):n.cwd&&n.cwd.length>0?Be(Nw.resolve(n.cwd,t)):t}function Zw(t,e){return t.length>e?`${t.slice(0,e-1)}\u2026`:t}function eb(t,e){if(t.length<=e)return t;let n=t.slice(-(e-1)),s=n.indexOf("/");return s>=0&&s<e/2?`\u2026${n.slice(s)}`:`\u2026${n}`}function tb(t,e={}){let n=_e(t,"toolCallId")??_e(t,"id");if(!n)return null;let s=_e(t,"title"),r=s!==void 0?gf(ke(s),t,e):void 0,i=_e(t,"status"),o=Co(t),a=hf(t);if(!(r!==void 0||o!==null||a!==void 0||i==="completed"||i==="failed"||i==="rejected"||i==="cancelled"))return null;let c=_e(t,"name")??s;if(pf(c)){let u={kind:"exit-plan-mode",toolCallId:n},p=mf(t);return p!==null&&(u.plan=p),i!==void 0&&(u.status=i),u}let l={kind:"tool-call-update",toolCallId:n};if(r!==void 0&&(l.title=r),a!==void 0&&(l.detail=a),i!==void 0&&(l.status=i),o!==null&&(l.editDiff=o),i==="failed"){let u=nb(t);u!==null&&(l.errorText=u),sb(t,u)&&(l.upstreamInterrupted=!0)}let f=Xr(t);return f!==void 0&&(l.workerTaskId=f),l}function nb(t){let e=t.content;if(Array.isArray(e))for(let s of e){if(!s||typeof s!="object")continue;let i=Zr(s.content);if(i!==null&&i.length>0)return i}let n=t.rawOutput;if(n&&typeof n=="object"){let s=n.error;if(typeof s=="string"&&s.length>0)return ct(s)}return null}function sb(t,e){let n=t.rawOutput;if(n&&typeof n=="object"){let s=n.metadata;if(s&&typeof s=="object"&&s.interrupted===!0)return!0}return!!(e!==null&&e.toLowerCase().includes("tool execution aborted"))}function rb(t){let e=t.entries;if(!Array.isArray(e)||e.length===0)return null;let n=[];for(let s of e){if(!s||typeof s!="object")continue;let r=s,i=typeof r.content=="string"?ke(r.content):void 0;if(!i)continue;let o={content:i};typeof r.status=="string"&&(o.status=r.status),typeof r.priority=="string"&&(o.priority=r.priority),n.push(o)}return{kind:"plan",entries:n}}function ib(t){let e=_e(t,"currentModeId")??_e(t,"currentMode")??_e(t,"mode");return e?{kind:"mode-changed",mode:ke(e)}:null}function ob(t){let e=_e(t,"currentModel")??_e(t,"model");if(!e)return null;let n=t.availableModels,s=Array.isArray(n)?n.map(r=>typeof r=="object"&&r!==null?r.modelId:typeof r=="string"?r:void 0).filter(r=>typeof r=="string"&&r.length>0):void 0;return{kind:"model-changed",model:ke(e),...s&&s.length>0?{availableModels:s}:{}}}function ab(t){let e=_e(t,"stopReason"),n=t._meta,s=n?.["hydra-acp"]?.amended!==void 0&&n["hydra-acp"].amended!==null,r={kind:"turn-complete"};return e!==void 0&&(r.stopReason=e),s&&(r.amended=!0),r}function Zr(t){if(typeof t=="string")return ct(t);if(!t||typeof t!="object")return null;let e=t;return e.type==="text"&&typeof e.text=="string"||typeof e.text=="string"?ct(e.text):null}function db(t){if(!Array.isArray(t))return null;let e=[];for(let n of t){let s=Zr(n);s!==null&&e.push(s)}return e.length===0?null:e.join("")}function _e(t,e){let n=t[e];return typeof n=="string"?n:void 0}var Hw,ff,Gw,ps=V(()=>{"use strict";ue();lf();Hw=/[\x00-\x08\x0b-\x1f\x7f]/g;ff=64;Gw=["home/","Users/","root/","tmp/","var/","opt/","etc/","usr/","mnt/","private/"]});function tr(t){let e=new Map,n=new Map;for(let r of t){let o=r.params?.update;if(!o||typeof o!="object")continue;let a=o.sessionUpdate;if(a!=="tool_call"&&a!=="tool_call_update")continue;let d=typeof o.toolCallId=="string"&&o.toolCallId.length>0?o.toolCallId:void 0,c=lb(o);if(c.length===0)continue;let l=c;if(d!==void 0){let f=e.get(d)??[],u=[];for(let p of c)f.some(g=>g.path===p.path&&g.oldText===p.oldText&&g.newText===p.newText)||u.push(p);if(u.length===0)continue;e.set(d,[...f,...u]),l=u}for(let f of l)cb(n,f)}let s=[];for(let[r,i]of n)s.push({path:r,hunks:i.hunks,created:i.created});return s}function nr(t){let e=[];for(let n of t){let s=-1;for(let i=e.length-1;i>=0;i--)if(e[i].newText===n.oldText){s=i;break}if(s===-1){e.push(n);continue}let r=e[s];e.splice(s,1,{oldText:r.oldText,newText:n.newText})}return e}function cb(t,e){let n={oldText:e.oldText,newText:e.newText},s=t.get(e.path);if(s===void 0){t.set(e.path,{hunks:[n],created:e.oldText.length===0});return}s.hunks.push(n)}function lb(t){let e=[],n=t.rawInput;if(n&&typeof n=="object"&&!Array.isArray(n)){let i=n,o=typeof i.file_path=="string"?i.file_path:typeof i.path=="string"?i.path:void 0,a=i.edits;if(o!==void 0&&Array.isArray(a)){for(let d of a){if(!d||typeof d!="object")continue;let c=d,l=typeof c.old_string=="string"?c.old_string:void 0,f=typeof c.new_string=="string"?c.new_string:void 0;l===void 0||f===void 0||e.push({path:o,oldText:l,newText:f})}if(e.length>0)return e}}let s=t.content;if(Array.isArray(s)){for(let i of s){if(!i||typeof i!="object")continue;let o=i;if(o.type!=="diff")continue;let a=typeof o.path=="string"?o.path:void 0;if(a===void 0)continue;let d=typeof o.oldText=="string"?o.oldText:"",c=typeof o.newText=="string"?o.newText:"";e.push({path:a,oldText:d,newText:c})}if(e.length>0)return e}let r=Co(t);return r&&r.path&&e.push({path:r.path,oldText:r.oldText,newText:r.newText}),e}var Ro=V(()=>{"use strict";ps()});function To(t){let e=ub(t),n=fb(e),s=[];pb(s,t),mb(s,e,n);let r=s.join(`
|
|
67
|
+
`:"")}async function Uu(t,e){let n=e.replace(/\n+$/,"");n.length!==0&&(await Wr.mkdir(hd.dirname(t),{recursive:!0}),await Wr.appendFile(t,JSON.stringify(n)+`
|
|
68
|
+
`,{encoding:"utf8"}))}function io(t,e){if(e.length===0)return[...t];let n=new Set(e);return[...t.filter(r=>!n.has(r)),...e]}function gd(t,e,n=Hu){if(e.length===0)return t;let s=new Set(t),r=t;for(let i of e){let o=i.replace(/\n+$/,"");o.length!==0&&(s.has(o)||(s.add(o),r=Jr(r,o,n)))}return r}var Hu,oo=V(()=>{"use strict";Hu=500});import{z as ye}from"zod";function Kr(t){let e={version:1,exportedAt:new Date().toISOString(),exportedFrom:{hydraVersion:t.hydraVersion,machine:t.machine,...t.hydraHost!==void 0&&t.hydraHost.length>0?{hydraHost:t.hydraHost}:{}},session:{sessionId:t.record.sessionId,lineageId:t.record.lineageId,...t.record.upstreamSessionId?{upstreamSessionId:t.record.upstreamSessionId}:{},agentId:t.record.agentId,cwd:t.record.cwd,...t.record.title!==void 0?{title:t.record.title}:{},...t.record.synopsis!==void 0?{synopsis:t.record.synopsis}:{},...t.record.summarizedThroughEntry!==void 0?{summarizedThroughEntry:t.record.summarizedThroughEntry}:{},...t.record.currentModel!==void 0?{currentModel:t.record.currentModel}:{},...t.record.currentMode!==void 0?{currentMode:t.record.currentMode}:{},...t.record.currentUsage!==void 0?{currentUsage:t.record.currentUsage}:{},...t.record.agentCommands!==void 0?{agentCommands:t.record.agentCommands}:{},...t.record.agentModes!==void 0?{agentModes:t.record.agentModes}:{},...t.record.interactive!==void 0?{interactive:t.record.interactive}:{},...t.record.originatingClient!==void 0?{originatingClient:t.record.originatingClient}:{},...t.record.priority!==void 0&&t.record.priority>0?{priority:t.record.priority}:{},createdAt:t.record.createdAt,updatedAt:t.record.updatedAt},history:t.history};return t.promptHistory!==void 0&&(e.promptHistory=t.promptHistory),t.toolBlobs!==void 0&&Object.keys(t.toolBlobs).length>0&&(e.toolBlobs=t.toolBlobs),e}function Bt(t){return pw.parse(t)}var uw,fw,pw,us=V(()=>{"use strict";od();Zi();uw=ye.object({method:ye.string(),params:ye.unknown(),recordedAt:ye.number()}),fw=ye.object({sessionId:ye.string(),lineageId:ye.string(),upstreamSessionId:ye.string().optional(),agentId:ye.string(),cwd:ye.string(),title:ye.string().optional(),synopsis:Hr.optional(),summarizedThroughEntry:ye.number().int().nonnegative().optional(),currentModel:ye.string().optional(),currentMode:ye.string().optional(),currentUsage:sd.optional(),agentCommands:ye.array(td).optional(),agentModes:ye.array(nd).optional(),interactive:ye.boolean().optional(),originatingClient:rd.optional(),priority:ye.number().int().nonnegative().optional(),createdAt:ye.string(),updatedAt:ye.string()}),pw=ye.object({version:ye.literal(1),exportedAt:ye.string(),exportedFrom:ye.object({hydraVersion:ye.string(),machine:ye.string(),hydraHost:ye.string().optional()}),session:fw,history:ye.array(uw),promptHistory:ye.array(ye.string()).optional(),toolBlobs:ye.record(ye.string()).optional()})});import{createHash as Rw}from"crypto";function Sd(t){if(Array.isArray(t))return t.map(Sd);if(t!==null&&typeof t=="object"){let e={};for(let n of Object.keys(t).sort())e[n]=Sd(t[n]);return e}return t}function er(t){let e=JSON.stringify(Sd(t));return Rw("sha256").update(e).digest("hex").slice(0,16)}var wo=V(()=>{"use strict";Ne()});function Xr(t){if(!t||typeof t!="object")return;let e=t;return typeof e.workerTaskId=="string"?e.workerTaskId:void 0}var uf=V(()=>{"use strict"});import{posix as Dw}from"path";import Hw from"strip-ansi";function ct(t){return Hw(t).replace(Uw,"")}function ke(t){return ct(t).replace(/[\n\t]+/g," ").replace(/ +/g," ").trim()}function ps(t,e={}){if(!t||typeof t!="object")return null;let n=t,s=n.sessionUpdate??n.kind;if(typeof s!="string")return null;switch(s){case"agent_message_chunk":return Kw(n);case"agent_thought_chunk":case"agent_thought":return Vw(n);case"user_message_chunk":return Yw(n);case"prompt_received":return Qw(n);case"tool_call":return Gw(n,e);case"tool_call_update":return nb(n,e);case"plan":return ib(n);case"current_mode_update":return ob(n);case"current_model_update":return ab(n);case"turn_complete":return db(n);case"usage_update":return Jw(n);case"available_commands_update":return Ww(n);case"available_modes_update":return zw(n);case"session_info_update":return qw(n);case"config_option_update":return jw(n);default:return{kind:"unknown",sessionUpdate:s,raw:t}}}function jw(t){let e=t.configOptions;if(!Array.isArray(e))return null;let n=[];for(let s of e){if(!s||typeof s!="object")continue;let r=s;if(typeof r.id!="string"||typeof r.currentValue!="string"||!Array.isArray(r.options))continue;let i=[];for(let o of r.options){if(!o||typeof o!="object")continue;let a=o;typeof a.value=="string"&&i.push({value:a.value,name:typeof a.name=="string"?a.name:a.value,...typeof a.description=="string"?{description:a.description}:{}})}n.push({id:r.id,name:typeof r.name=="string"?r.name:r.id,type:"select",currentValue:r.currentValue,options:i,...typeof r.category=="string"?{category:r.category}:{}})}return{kind:"config-options",options:n}}function qw(t){let e=_e(t,"title"),n=e!==void 0?ke(e):void 0,s=t._meta,r;if(s&&typeof s=="object"&&!Array.isArray(s)){let o=s["hydra-acp"];if(o&&typeof o=="object"&&!Array.isArray(o)){let a=o.agentId;typeof a=="string"&&(r=a)}}if(n===void 0&&r===void 0)return null;let i={kind:"session-info"};return n!==void 0&&(i.title=n),r!==void 0&&(i.agentId=r),i}function Ao(t){if(!Array.isArray(t))return[];let e=[];for(let n of t){if(!n||typeof n!="object")continue;let s=n;if(typeof s.name!="string"||s.name.length===0)continue;let r=s.name.startsWith("/")?s.name:`/${s.name}`,i={name:ke(r)};typeof s.description=="string"&&(i.description=ke(s.description)),e.push(i)}return e}function Ww(t){let e=t.availableCommands??t.commands;return Array.isArray(e)?{kind:"available-commands",commands:Ao(e)}:null}function zw(t){let e=t.availableModes;if(!Array.isArray(e))return null;let n=[];for(let s of e){if(!s||typeof s!="object")continue;let r=s;if(typeof r.id!="string"||r.id.length===0)continue;let i={id:ke(r.id)};typeof r.name=="string"&&(i.name=ke(r.name)),typeof r.description=="string"&&(i.description=ke(r.description)),n.push(i)}return{kind:"available-modes",modes:n}}function Jw(t){let e={kind:"usage-update"};if(typeof t.used=="number"&&(e.used=t.used),typeof t.size=="number"&&(e.size=t.size),t.cost&&typeof t.cost=="object"){let n=t.cost;typeof n.amount=="number"&&(e.costAmount=n.amount),typeof n.currency=="string"&&(e.costCurrency=n.currency)}return e}function Kw(t){let e=Zr(t.content);return e===null?null:{kind:"agent-text",text:e,workerTaskId:Xr(t)}}function Vw(t){let e=typeof t.text=="string"?ct(t.text):Zr(t.content);return e===null?null:{kind:"agent-thought",text:e,workerTaskId:Xr(t)}}function Yw(t){let e=t._meta;if(e&&typeof e=="object"&&!Array.isArray(e)){let s=e["hydra-acp"];if(s&&typeof s=="object"&&!Array.isArray(s)&&s.compatFor==="prompt_received")return null}let n=Zr(t.content);return n===null?null:{kind:"user-text",text:n}}function Qw(t){let e=cb(t.prompt);return e===null?null:{kind:"user-text",text:e}}function mf(t){return t?t.toLowerCase().replace(/[_\s-]/g,"")==="exitplanmode":!1}function ff(t){if(typeof t=="string")return{text:t};if(t&&typeof t=="object"&&!Array.isArray(t)){let e=t;if(typeof e.__hydraBlob=="string")return{ref:{hash:e.__hydraBlob,bytes:typeof e.bytes=="number"?e.bytes:0}}}}function Co(t){let e=t.content;if(Array.isArray(e))for(let s of e){if(!s||typeof s!="object")continue;let r=s;if(r.type!=="diff")continue;let i=ff(r.oldText),o=ff(r.newText);if(i===void 0&&o===void 0)continue;let a=typeof r.path=="string"?r.path:void 0;return{...a!==void 0?{path:a}:{},oldText:i?.text??"",newText:o?.text??"",...i?.ref?{oldRef:i.ref}:{},...o?.ref?{newRef:o.ref}:{}}}let n=t.rawInput;if(n&&typeof n=="object"&&!Array.isArray(n)){let s=n,r=typeof s.file_path=="string"?s.file_path:typeof s.path=="string"?s.path:void 0;if(typeof s.old_string=="string"&&typeof s.new_string=="string")return{...r!==void 0?{path:r}:{},oldText:s.old_string,newText:s.new_string};if(typeof s.content=="string")return{...r!==void 0?{path:r}:{},oldText:"",newText:s.content}}return null}function hf(t){let e=t.rawInput;if(!e||typeof e!="object"||Array.isArray(e))return null;let n=e.plan;return typeof n!="string"||n.length===0?null:ct(n)}function Gw(t,e={}){let n=_e(t,"toolCallId")??_e(t,"id");if(!n)return null;let s=_e(t,"title")??_e(t,"name")??_e(t,"label")??"tool call",r=_e(t,"name")??_e(t,"title");if(mf(r)){let u=hf(t);if(u!==null){let p=_e(t,"status"),g={kind:"exit-plan-mode",toolCallId:n,plan:u};return p!==void 0&&(g.status=p),g}}let i=yf(ke(s),t,e),o=_e(t,"status"),a=_e(t,"kind"),d={kind:"tool-call",toolCallId:n,title:i};o!==void 0&&(d.status=o),a!==void 0&&(d.rawKind=a);let c=Co(t);c!==null&&(d.editDiff=c);let l=gf(t);l!==void 0&&(d.detail=l);let f=Xr(t);return f!==void 0&&(d.workerTaskId=f),d}function gf(t){let e=t.rawInput;if(!e||typeof e!="object"||Array.isArray(e))return;let n=e;if(typeof n.command=="string"&&n.command.trim().length>0){let i=ke(n.command).trim().replace(/^cd\s+\S+\s+&&\s+/,"");return eb(i,pf)}let s=typeof n.file_path=="string"?n.file_path:typeof n.filePath=="string"?n.filePath:typeof n.path=="string"?n.path:void 0;if(s!==void 0&&s.length>0)return tb(Be(ke(s)),pf)}function Zw(t){for(let e of Xw)if(t.startsWith(e))return!0;return!1}function yf(t,e,n={}){if(t.length===0)return t;if(t.startsWith("/"))return Be(t);if(t.startsWith("~")||!t.includes("/")||/\s/.test(t))return t;let s=e.rawInput;if(s&&typeof s=="object"&&!Array.isArray(s)){let r=s,i=[r.file_path,r.filePath,r.path];for(let o of i)if(!(typeof o!="string"||o.length===0)&&(o===`/${t}`||o.endsWith(`/${t}`)||o===t))return Be(o)}return Zw(t)?Be(`/${t}`):n.cwd&&n.cwd.length>0?Be(Dw.resolve(n.cwd,t)):t}function eb(t,e){return t.length>e?`${t.slice(0,e-1)}\u2026`:t}function tb(t,e){if(t.length<=e)return t;let n=t.slice(-(e-1)),s=n.indexOf("/");return s>=0&&s<e/2?`\u2026${n.slice(s)}`:`\u2026${n}`}function nb(t,e={}){let n=_e(t,"toolCallId")??_e(t,"id");if(!n)return null;let s=_e(t,"title"),r=s!==void 0?yf(ke(s),t,e):void 0,i=_e(t,"status"),o=Co(t),a=gf(t);if(!(r!==void 0||o!==null||a!==void 0||i==="completed"||i==="failed"||i==="rejected"||i==="cancelled"))return null;let c=_e(t,"name")??s;if(mf(c)){let u={kind:"exit-plan-mode",toolCallId:n},p=hf(t);return p!==null&&(u.plan=p),i!==void 0&&(u.status=i),u}let l={kind:"tool-call-update",toolCallId:n};if(r!==void 0&&(l.title=r),a!==void 0&&(l.detail=a),i!==void 0&&(l.status=i),o!==null&&(l.editDiff=o),i==="failed"){let u=sb(t);u!==null&&(l.errorText=u),rb(t,u)&&(l.upstreamInterrupted=!0)}let f=Xr(t);return f!==void 0&&(l.workerTaskId=f),l}function sb(t){let e=t.content;if(Array.isArray(e))for(let s of e){if(!s||typeof s!="object")continue;let i=Zr(s.content);if(i!==null&&i.length>0)return i}let n=t.rawOutput;if(n&&typeof n=="object"){let s=n.error;if(typeof s=="string"&&s.length>0)return ct(s)}return null}function rb(t,e){let n=t.rawOutput;if(n&&typeof n=="object"){let s=n.metadata;if(s&&typeof s=="object"&&s.interrupted===!0)return!0}return!!(e!==null&&e.toLowerCase().includes("tool execution aborted"))}function ib(t){let e=t.entries;if(!Array.isArray(e)||e.length===0)return null;let n=[];for(let s of e){if(!s||typeof s!="object")continue;let r=s,i=typeof r.content=="string"?ke(r.content):void 0;if(!i)continue;let o={content:i};typeof r.status=="string"&&(o.status=r.status),typeof r.priority=="string"&&(o.priority=r.priority),n.push(o)}return{kind:"plan",entries:n}}function ob(t){let e=_e(t,"currentModeId")??_e(t,"currentMode")??_e(t,"mode");return e?{kind:"mode-changed",mode:ke(e)}:null}function ab(t){let e=_e(t,"currentModel")??_e(t,"model");if(!e)return null;let n=t.availableModels,s=Array.isArray(n)?n.map(r=>typeof r=="object"&&r!==null?r.modelId:typeof r=="string"?r:void 0).filter(r=>typeof r=="string"&&r.length>0):void 0;return{kind:"model-changed",model:ke(e),...s&&s.length>0?{availableModels:s}:{}}}function db(t){let e=_e(t,"stopReason"),n=t._meta,s=n?.["hydra-acp"]?.amended!==void 0&&n["hydra-acp"].amended!==null,r={kind:"turn-complete"};return e!==void 0&&(r.stopReason=e),s&&(r.amended=!0),r}function Zr(t){if(typeof t=="string")return ct(t);if(!t||typeof t!="object")return null;let e=t;return e.type==="text"&&typeof e.text=="string"||typeof e.text=="string"?ct(e.text):null}function cb(t){if(!Array.isArray(t))return null;let e=[];for(let n of t){let s=Zr(n);s!==null&&e.push(s)}return e.length===0?null:e.join("")}function _e(t,e){let n=t[e];return typeof n=="string"?n:void 0}var Uw,pf,Xw,ms=V(()=>{"use strict";ue();uf();Uw=/[\x00-\x08\x0b-\x1f\x7f]/g;pf=64;Xw=["home/","Users/","root/","tmp/","var/","opt/","etc/","usr/","mnt/","private/"]});function tr(t){let e=new Map,n=new Map;for(let r of t){let o=r.params?.update;if(!o||typeof o!="object")continue;let a=o.sessionUpdate;if(a!=="tool_call"&&a!=="tool_call_update")continue;let d=typeof o.toolCallId=="string"&&o.toolCallId.length>0?o.toolCallId:void 0,c=ub(o);if(c.length===0)continue;let l=c;if(d!==void 0){let f=e.get(d)??[],u=[];for(let p of c)f.some(g=>g.path===p.path&&g.oldText===p.oldText&&g.newText===p.newText)||u.push(p);if(u.length===0)continue;e.set(d,[...f,...u]),l=u}for(let f of l)lb(n,f)}let s=[];for(let[r,i]of n)s.push({path:r,hunks:i.hunks,created:i.created});return s}function nr(t){let e=[];for(let n of t){let s=-1;for(let i=e.length-1;i>=0;i--)if(e[i].newText===n.oldText){s=i;break}if(s===-1){e.push(n);continue}let r=e[s];e.splice(s,1,{oldText:r.oldText,newText:n.newText})}return e}function lb(t,e){let n={oldText:e.oldText,newText:e.newText},s=t.get(e.path);if(s===void 0){t.set(e.path,{hunks:[n],created:e.oldText.length===0});return}s.hunks.push(n)}function ub(t){let e=[],n=t.rawInput;if(n&&typeof n=="object"&&!Array.isArray(n)){let i=n,o=typeof i.file_path=="string"?i.file_path:typeof i.path=="string"?i.path:void 0,a=i.edits;if(o!==void 0&&Array.isArray(a)){for(let d of a){if(!d||typeof d!="object")continue;let c=d,l=typeof c.old_string=="string"?c.old_string:void 0,f=typeof c.new_string=="string"?c.new_string:void 0;l===void 0||f===void 0||e.push({path:o,oldText:l,newText:f})}if(e.length>0)return e}}let s=t.content;if(Array.isArray(s)){for(let i of s){if(!i||typeof i!="object")continue;let o=i;if(o.type!=="diff")continue;let a=typeof o.path=="string"?o.path:void 0;if(a===void 0)continue;let d=typeof o.oldText=="string"?o.oldText:"",c=typeof o.newText=="string"?o.newText:"";e.push({path:a,oldText:d,newText:c})}if(e.length>0)return e}let r=Co(t);return r&&r.path&&e.push({path:r.path,oldText:r.oldText,newText:r.newText}),e}var Ro=V(()=>{"use strict";ms()});function To(t){let e=fb(t),n=pb(e),s=[];mb(s,t),hb(s,e,n);let r=s.join(`
|
|
49
69
|
`);return r.endsWith(`
|
|
50
70
|
`)||(r+=`
|
|
51
|
-
`),r}function
|
|
52
|
-
`)),t.push("")}function
|
|
53
|
-
`))t.push(`> ${
|
|
54
|
-
`);for(let f of l)t.push(`> _${
|
|
55
|
-
`),Ho(),await Uo(t))}async function si(t){let n=`${t.daemon.tls?"https":"http"}://${t.daemon.host}:${t.daemon.port}/v1/health`;try{return(await fetch(n,{signal:AbortSignal.timeout(500),headers:{Connection:"close"}})).ok}catch{return!1}}async function Do(t,e=1e3){let s=`${t.daemon.tls?"https":"http"}://${t.daemon.host}:${t.daemon.port}/v1/health`;try{let r=await fetch(s,{signal:AbortSignal.timeout(e),headers:{Connection:"close"}});if(!r.ok)return;let i=await r.json();return{version:typeof i.version=="string"?i.version:void 0,configDigest:typeof i.configDigest=="string"?i.configDigest:void 0}}catch{return}}function Ho(){let t=process.argv[1];if(!t)throw new Error("Cannot determine hydra-acp binary path to spawn daemon");
|
|
71
|
+
`),r}function fb(t){let e=[];for(let n of t.history){if(n.method!=="session/update")continue;let s=n.params;if(!s||typeof s!="object")continue;let r=ps(s.update,{cwd:t.session.cwd});r!==null&&e.push({event:r,recordedAt:n.recordedAt})}return e}function pb(t){let e=new Map;for(let{event:n}of t){if(n.kind==="tool-call"){let s=e.get(n.toolCallId);e.set(n.toolCallId,{title:n.title,status:n.status??s?.status??"pending"});continue}if(n.kind==="tool-call-update"){let s=e.get(n.toolCallId)??{title:"tool call",status:"pending"};e.set(n.toolCallId,{title:n.title??s.title,status:n.status??s.status})}}return e}function mb(t,e){let n=e.session,s=He(n.sessionId),r=n.title?.trim()||`Hydra session ${s}`;t.push(`# ${hs(r)}`),t.push("");let i=[];i.push(`- **Session:** \`${s}\` (lineage \`${n.lineageId}\`)`);let o=[n.agentId];n.currentModel&&o.push(`model: ${n.currentModel}`),n.currentMode&&o.push(`mode: ${n.currentMode}`),i.push(`- **Agent:** ${o.filter(Boolean).join(" \xB7 ")}`),i.push(`- **Cwd:** ${n.cwd}`),i.push(`- **Exported:** ${e.exportedAt} from ${e.exportedFrom.machine} (hydra ${e.exportedFrom.hydraVersion})`);let a=n.currentUsage;if(a&&(a.used!==void 0||a.costAmount!==void 0)){let d=[];if(a.used!==void 0){let c=a.size!==void 0?`${kd(a.size)}`:void 0;d.push(c?`${kd(a.used)} / ${c} tokens`:`${kd(a.used)} tokens`)}if(a.costAmount!==void 0){let c=a.costCurrency??"USD";d.push(`$${a.costAmount.toFixed(2)} ${c}`)}i.push(`- **Usage:** ${d.join(" \xB7 ")}`)}t.push(i.join(`
|
|
72
|
+
`)),t.push("")}function hb(t,e,n){if(!e.some(c=>gb(c.event))){t.push("_No conversation history recorded._"),t.push("");return}let s=new Set,r=0,i="",o=!1,a=()=>{i.length!==0&&(t.push(i.trimEnd()),t.push(""),i="")},d=()=>{o||(r+=1,t.push("---"),t.push(""),t.push(`## Turn ${r}`),t.push(""),o=!0)};for(let{event:c}of e)switch(c.kind){case"user-text":{a(),r+=1,t.push("---"),t.push(""),t.push(`## Turn ${r}`),t.push(""),t.push("**User:**"),t.push("");for(let l of c.text.split(`
|
|
73
|
+
`))t.push(`> ${hs(l)}`);t.push(""),t.push("**Assistant:**"),t.push(""),o=!0;break}case"agent-text":d(),i+=c.text;break;case"agent-thought":{d(),a();let l=c.text.split(`
|
|
74
|
+
`);for(let f of l)t.push(`> _${hs(f)}_`);t.push("");break}case"tool-call":{if(d(),a(),s.has(c.toolCallId))break;s.add(c.toolCallId);let l=n.get(c.toolCallId)??{title:c.title,status:c.status??"pending"};t.push(`- ${wb(l.status)} ${yb(l)}`),t.push("");break}case"tool-call-update":break;case"plan":{d(),a(),t.push("**Plan:**"),t.push("");for(let l of c.entries){let f=l.status==="completed"?"[x]":"[ ]";t.push(`- ${f} ${hs(l.content)}`)}t.push("");break}case"mode-changed":d(),a(),t.push(`_mode: ${hs(c.mode)}_`),t.push("");break;case"model-changed":d(),a(),t.push(`_model: ${hs(c.model)}_`),t.push("");break;case"turn-complete":a();break;case"usage-update":case"available-commands":case"session-info":case"unknown":break}a()}function gb(t){switch(t.kind){case"usage-update":case"available-commands":case"session-info":case"unknown":case"turn-complete":return!1;default:return!0}}function yb(t){let e=t.status,n=e==="completed"||e===void 0?"":` _(${e})_`;return`${hs(t.title)}${n}`}function wb(t){switch(t){case"completed":return"\u2713";case"failed":return"\u2717";case"cancelled":case"rejected":return"\u2298";case"in_progress":return"\u21BB";default:return"\xB7"}}function hs(t){return t.replace(/</g,"<").replace(/>/g,">")}function kd(t){return t.toLocaleString("en-US")}var xd=V(()=>{"use strict";ms();Yt()});function rr(t){let e=[],n=[],s=!1,r=i=>{if(!s){s=!0;for(let o of n)o(i)}};return t.on("message",(i,o)=>{if(o)return;let a=i.toString("utf8");try{let d=JSON.parse(a);for(let c of e)c(d)}catch(d){for(let c of e)c({jsonrpc:"2.0",id:0,error:{code:B.ParseError,message:`Failed to parse WS frame: ${d.message}`}})}}),t.on("close",()=>r()),t.on("error",i=>r(i)),{async send(i){if(s)throw new Error("ws is closed");let o=JSON.stringify(i);await new Promise((a,d)=>{t.send(o,c=>{if(c){d(c);return}a()})})},onMessage(i){e.push(i)},onClose(i){n.push(i)},async close(){s||(t.close(),r())}}}var $o=V(()=>{"use strict";dt()});import{spawn as mv}from"child_process";import{setTimeout as hv}from"timers/promises";async function ir(t){await si(t)||(process.stderr.write(`hydra-acp: daemon not running; starting it...
|
|
75
|
+
`),Ho(),await Uo(t))}async function si(t){let n=`${t.daemon.tls?"https":"http"}://${t.daemon.host}:${t.daemon.port}/v1/health`;try{return(await fetch(n,{signal:AbortSignal.timeout(500),headers:{Connection:"close"}})).ok}catch{return!1}}async function Do(t,e=1e3){let s=`${t.daemon.tls?"https":"http"}://${t.daemon.host}:${t.daemon.port}/v1/health`;try{let r=await fetch(s,{signal:AbortSignal.timeout(e),headers:{Connection:"close"}});if(!r.ok)return;let i=await r.json();return{version:typeof i.version=="string"?i.version:void 0,configDigest:typeof i.configDigest=="string"?i.configDigest:void 0}}catch{return}}function Ho(){let t=process.argv[1];if(!t)throw new Error("Cannot determine hydra-acp binary path to spawn daemon");mv(process.execPath,[t,"daemon","start","--foreground"],{detached:!0,stdio:"ignore",env:process.env}).unref()}async function Uo(t,e=15e3){let n=Date.now()+e;for(;Date.now()<n;){if(await si(t))return;await hv(150)}throw new Error(`hydra-acp daemon did not become ready within ${e}ms`)}var ri=V(()=>{"use strict"});async function cn(t,e={},n=fetch){let s=new URL(`${t.baseUrl}/v1/sessions`);e.cwd&&s.searchParams.set("cwd",e.cwd),e.all&&s.searchParams.set("all","true"),e.includeNonInteractive&&s.searchParams.set("includeNonInteractive","true");let r=await n(s.toString(),{headers:{Authorization:`Bearer ${t.token}`}});if(!r.ok)throw new Error(`daemon returned HTTP ${r.status}`);let i=await r.json();return Array.isArray(i.sessions)?i.sessions.map(o=>({sessionId:o.sessionId,cwd:o.cwd,updatedAt:o.updatedAt,attachedClients:o.attachedClients??0,status:o.status??"live",upstreamSessionId:o.upstreamSessionId,agentId:o.agentId,currentModel:o.currentModel,currentUsage:o.currentUsage,title:o.title,importedFromMachine:o.importedFromMachine,importedFromUpstreamSessionId:o.importedFromUpstreamSessionId,forkedFromSessionId:o.forkedFromSessionId,forkedFromMessageId:o.forkedFromMessageId,busy:o.busy,awaitingInput:o.awaitingInput,originatingClient:o.originatingClient,interactive:o.interactive,priority:o.priority})):[]}async function sp(t,e=fetch){let n=await e(`${t.baseUrl}/v1/agents`,{headers:{Authorization:`Bearer ${t.token}`}});if(!n.ok)throw new Error(`daemon returned HTTP ${n.status}`);let s=await n.json(),r=Array.isArray(s.agents)?s.agents.filter(d=>d.installed==="yes"):[],i=0,o=0,a=0;for(let d of r)try{let c=await e(`${t.baseUrl}/v1/agents/${d.id}/sync`,{method:"POST",headers:{Authorization:`Bearer ${t.token}`}});if(!c.ok)continue;let l=await c.json();i+=Array.isArray(l.synced)?l.synced.length:0,o+=typeof l.skipped=="number"?l.skipped:0,a+=1}catch{}return{synced:i,skipped:o,agents:a}}async function rp(t,e=fetch){let n=await e(`${t.baseUrl}/v1/agents`,{headers:{Authorization:`Bearer ${t.token}`}});if(!n.ok)throw new Error(`daemon returned HTTP ${n.status}`);let s=await n.json();return Array.isArray(s.agents)?s.agents.map(r=>({id:r.id,name:r.name,description:r.description})):[]}async function ip(t,e,n={},s=fetch){let r=await s(`${t.baseUrl}/v1/sessions/${e}/fork`,{method:"POST",headers:{Authorization:`Bearer ${t.token}`,"Content-Type":"application/json"},body:JSON.stringify(n)});if(!r.ok){let i="";try{let o=await r.json();typeof o.error=="string"&&(i=`: ${o.error}`)}catch{}throw new Error(`fork failed (HTTP ${r.status})${i}`)}return await r.json()}async function op(t,e,n=fetch){let s=await n(`${t.baseUrl}/v1/sessions/${e}/kill`,{method:"POST",headers:{Authorization:`Bearer ${t.token}`}});if(!s.ok&&s.status!==204&&s.status!==404)throw new Error(`daemon returned HTTP ${s.status}`)}async function ap(t,e,n,s=fetch){let r=await s(`${t.baseUrl}/v1/sessions/${e}`,{method:"PATCH",headers:{Authorization:`Bearer ${t.token}`,"Content-Type":"application/json"},body:JSON.stringify({title:n})});if(!r.ok&&r.status!==204&&r.status!==404)throw new Error(`daemon returned HTTP ${r.status}`)}async function dp(t,e,n,s=fetch){let r=await s(`${t.baseUrl}/v1/sessions/${e}`,{method:"PATCH",headers:{Authorization:`Bearer ${t.token}`,"Content-Type":"application/json"},body:JSON.stringify({priority:n})});if(!r.ok&&r.status!==204&&r.status!==404)throw new Error(`daemon returned HTTP ${r.status}`)}async function cp(t,e,n=fetch){let s=await n(`${t.baseUrl}/v1/sessions/${e}`,{method:"PATCH",headers:{Authorization:`Bearer ${t.token}`,"Content-Type":"application/json"},body:JSON.stringify({regen:!0})});if(!s.ok&&s.status!==202&&s.status!==204&&s.status!==404&&s.status!==409)throw new Error(`daemon returned HTTP ${s.status}`)}async function lp(t,e,n={},s=fetch){let r={q:e};n.sessionIds&&n.sessionIds.length>0&&(r.sessionIds=n.sessionIds);let i=await s(`${t.baseUrl}/v1/sessions/search`,{method:"POST",headers:{Authorization:`Bearer ${t.token}`,"Content-Type":"application/json"},body:JSON.stringify(r)});if(!i.ok)throw new Error(`daemon returned HTTP ${i.status}`);return await i.json()}async function up(t,e,n=fetch){let s=await n(`${t.baseUrl}/v1/sessions/${e}`,{method:"DELETE",headers:{Authorization:`Bearer ${t.token}`}});if(!s.ok&&s.status!==204&&s.status!==404)throw new Error(`daemon returned HTTP ${s.status}`)}function jo(t,e){let n=t.filter(i=>i.cwd===e);if(n.length===0)return null;let s=i=>i.status==="live"?1:0;return[...n].sort((i,o)=>{let a=s(o)-s(i);return a!==0?a:o.updatedAt.localeCompare(i.updatedAt)})[0]??null}var qo=V(()=>{"use strict"});function $d(t){if(!t)return;let e=t.lastIndexOf("/");return e===-1?t:t.slice(e+1)}function fp(t,e){let n=t??"?",s=$d(e);return s?`${n}${vv}${s}`:n}function pp(t){return t??"?"}function mp(t){if(!t||typeof t.costAmount!="number")return"";let{costAmount:e,costCurrency:n}=t;return n===void 0||n==="USD"?`$${Math.round(e)}`:_d(e,n)}function _d(t,e){return`${e==="USD"||e===void 0?"$":""}${t.toFixed(2)}${e&&e!=="USD"?` ${e}`:""}`}var vv,Fd=V(()=>{"use strict";vv="\u2022"});function hp(t){let e=t.split(",").map(r=>r.trim()).filter(r=>r.length>0);if(e.length===0)throw new Error("--columns: no column names given");let n=new Set,s=[];for(let r of e){if(!zo.includes(r))throw new Error(`--columns: unknown column "${r}" (valid: ${zo.join(", ")})`);if(n.has(r))throw new Error(`--columns: duplicate column "${r}"`);n.add(r),s.push(r)}return s}function ur(t,e=Date.now()){return{session:He(t.sessionId),upstream:Sv(t.upstreamSessionId,t.importedFromMachine),host:t.importedFromMachine??"-",state:kv(t.status,t.busy,t.awaitingInput),agent:pp(t.agentId),model:$d(t.currentModel)??"-",age:xv(t.updatedAt,e),title:t.title??"-",cwd:Be(t.cwd),cost:mp(t.currentUsage)}}function Sv(t,e){return t&&t.length>0?t:e&&e.length>0?`\u2190 ${e}`:"-"}function kv(t,e,n){return t==="cold"?"COLD":n?"LIVE\u25E6":e?"LIVE\u2022":"LIVE"}function fr(t,e={}){let n=e.columns??cr,s={session:0,upstream:0,host:0,state:0,agent:0,model:0,age:0,cwd:0,title:0,cost:0};for(let r of n)s[r]=Av(lr[r],t.map(i=>i[r]));return s}function xv(t,e){if(!t)return"?";let n=Date.parse(t);if(Number.isNaN(n))return"?";let s=Math.max(0,e-n),r=Math.floor(s/1e3);if(r<60)return"<1m";let i=Math.floor(r/60);if(i<60)return`${i}m`;let o=Math.floor(i/60);if(o<24)return`${o}h`;let a=Math.floor(o/24);if(a<14)return`${a}d`;let d=Math.floor(a/7);if(d<9)return`${d}w`;let c=Math.floor(a/30);return c<12?`${c}mo`:`${Math.floor(a/365)}y`}function Av(t,e){let n=t.length;for(let s of e)s.length>n&&(n=s.length);return n}function Dn(t,e,n,s={}){let r=s.columns??cr,i=s.cwdMaxWidth??Iv,o=b=>b==="age"?t[b].padStart(e[b]):t[b].padEnd(e[b]);if(n===void 0)return r.map((x,C)=>C===r.length-1?t[x]:o(x)).join(Wo);let a=r.map((b,x)=>({col:b,i:x})).filter(({col:b})=>Od.has(b)),d=a.length>0?a[a.length-1].i:-1;if(d===-1){let b=r.map(o).join(Wo);return b.length>n?b.slice(0,n):b}let c=r.filter(b=>!Od.has(b)).reduce((b,x)=>b+e[x],0),l=Math.max(0,r.length-1),f=n-c-l*Wo.length;f<0&&(f=0);let u=new Map,p=f;for(let{col:b,i:x}of a){if(x===d)continue;let C=b==="cwd"?Math.min(e[b],i):e[b],O=Math.min(C,Math.max(0,p-1));u.set(x,O),p=Math.max(0,p-O)}u.set(d,Math.max(0,p));let g=r.length-1,h=(b,x,C)=>{if(b==="cwd")return ii(t[b],x).padEnd(x);let O=Cv(t[b],x);return C?O:O.padEnd(x)},v=r.map((b,x)=>Od.has(b)?h(b,u.get(x)??0,x===g):o(b)).join(Wo);return v.length>n?v.slice(0,n):v}function Cv(t,e){return e<=0?"":t.length<=e?t:e===1?"\u2026":t.slice(0,e-1)+"\u2026"}function ii(t,e){if(e<=0)return"";if(t.length<=e)return t;if(e===1)return"\u2026";let n=Math.ceil((e-1)/2),s=e-1-n;return t.slice(0,n)+"\u2026"+t.slice(t.length-s)}var zo,cr,Od,lr,Wo,Iv,Jo=V(()=>{"use strict";Fd();ue();Yt();zo=["session","upstream","host","state","agent","model","age","cwd","title","cost"],cr=["session","state","age","cwd","title","agent","cost"],Od=new Set(["cwd","title"]),lr={session:"SESSION",upstream:"UPSTREAM",host:"HOST",state:"STATE",agent:"AGENT",model:"MODEL",age:"AGE",title:"TITLE",cwd:"CWD",cost:"COST"},Wo=" ",Iv=32});import*as Rt from"fs/promises";import*as Tt from"path";async function yp(t={}){let e=await Z(),n=await pe(),s=ge(e.daemon.host,e.daemon.port,!!e.daemon.tls),r=new URL(`${s}/v1/sessions`);(t.includeNonInteractive||t.all)&&r.searchParams.set("includeNonInteractive","true");let i=await fetch(r.toString(),{headers:{Authorization:`Bearer ${n}`}});i.ok||(process.stderr.write(`Daemon returned HTTP ${i.status}
|
|
56
76
|
`),process.exit(1));let o=await i.json(),a=o.sessions,d=t.host??"local",c=d==="all"?a:d==="local"?a.filter(b=>!b.importedFromMachine||!!b.upstreamSessionId):a.filter(b=>b.importedFromMachine===d&&!b.upstreamSessionId);if(t.json){process.stdout.write(JSON.stringify(c,null,2)+`
|
|
57
77
|
`);return}if(c.length===0){if(d==="local"&&o.sessions.length>0){process.stdout.write(`No local sessions. Use --host=all to include imported sessions.
|
|
58
78
|
`);return}if(d!=="local"&&d!=="all"){process.stdout.write(`No sessions from ${d}.
|
|
59
79
|
`);return}process.stdout.write(`No active sessions.
|
|
60
|
-
`);return}let l=c.slice().sort((b,x)=>{let C=(x.status==="live"?1:0)-(b.status==="live"?1:0);return C!==0?C:String(x.updatedAt||"").localeCompare(String(b.updatedAt||""))}),f=l,u=0;if(!t.all){let b=l.filter(q=>q.status!=="cold").length,x=e.sessionListColdLimit,C=l.slice(b,b+x),O=l.length-b-C.length;f=[...l.slice(0,b),...C],u=O}let p=Date.now(),g=f.map(b=>ur(b,p)),h={columns:t.columns??e.tui.sessionColumns??cr,cwdMaxWidth:e.tui.cwdColumnMaxWidth},w=fr(g,h),v=process.stdout.isTTY?process.stdout.columns:void 0;process.stdout.write(
|
|
61
|
-
`);for(let b of g)process.stdout.write(
|
|
80
|
+
`);return}let l=c.slice().sort((b,x)=>{let C=(x.status==="live"?1:0)-(b.status==="live"?1:0);return C!==0?C:String(x.updatedAt||"").localeCompare(String(b.updatedAt||""))}),f=l,u=0;if(!t.all){let b=l.filter(q=>q.status!=="cold").length,x=e.sessionListColdLimit,C=l.slice(b,b+x),O=l.length-b-C.length;f=[...l.slice(0,b),...C],u=O}let p=Date.now(),g=f.map(b=>ur(b,p)),h={columns:t.columns??e.tui.sessionColumns??cr,cwdMaxWidth:e.tui.cwdColumnMaxWidth},w=fr(g,h),v=process.stdout.isTTY?process.stdout.columns:void 0;process.stdout.write(Dn(lr,w,v,h)+`
|
|
81
|
+
`);for(let b of g)process.stdout.write(Dn(b,w,v,h)+`
|
|
62
82
|
`);u>0&&process.stdout.write(`
|
|
63
83
|
... ${u} more cold session${u===1?"":"s"} hidden. Use --all to show.
|
|
64
|
-
`)}async function
|
|
84
|
+
`)}async function wp(t){t||(process.stderr.write(`Usage: hydra-acp sessions kill <session-id>
|
|
65
85
|
`),process.exit(2));let e=await Z(),n=await pe(),s=ge(e.daemon.host,e.daemon.port,!!e.daemon.tls),r=await fetch(`${s}/v1/sessions/${t}/kill`,{method:"POST",headers:{Authorization:`Bearer ${n}`}});!r.ok&&r.status!==204&&(process.stderr.write(`Daemon returned HTTP ${r.status}
|
|
66
86
|
`),process.exit(1)),process.stdout.write(`Killed ${t}
|
|
67
|
-
`)}async function
|
|
87
|
+
`)}async function bp(t){t||(process.stderr.write(`Usage: hydra-acp sessions remove <session-id>
|
|
68
88
|
`),process.exit(2));let e=await Z(),n=await pe(),s=ge(e.daemon.host,e.daemon.port,!!e.daemon.tls),r=await fetch(`${s}/v1/sessions/${t}`,{method:"DELETE",headers:{Authorization:`Bearer ${n}`}});!r.ok&&r.status!==204&&(process.stderr.write(`Daemon returned HTTP ${r.status}
|
|
69
89
|
`),process.exit(1)),process.stdout.write(`Removed ${t}
|
|
70
|
-
`)}async function
|
|
90
|
+
`)}async function vp(t){let e=await Z(),n=await pe(),s=ge(e.daemon.host,e.daemon.port,!!e.daemon.tls),r=t.maxAgeDays!==void 0?t.maxAgeDays:0,i={maxAgeDays:r};t.limit!==void 0&&(i.limit=t.limit),i.selection=t.keepUndecided?"explicit":"unpromoted";let o=await fetch(`${s}/v1/sessions/collect`,{method:"POST",headers:{Authorization:`Bearer ${n}`,"Content-Type":"application/json"},body:JSON.stringify(i)});o.ok||(process.stderr.write(`Daemon returned HTTP ${o.status}
|
|
71
91
|
`),process.exit(1));let a=await o.json();if(t.json){process.stdout.write(`${JSON.stringify(a,null,2)}
|
|
72
92
|
`);return}let d=t.keepUndecided?"non-interactive":"unpromoted (cat one-shots + editor ghosts)";if(a.considered===0){let l=r>0?` older than ${r}d`:"";process.stdout.write(`No ${d} sessions${l} found.
|
|
73
|
-
`);return}let c=a.oldestLastUsedMs!==void 0?` (oldest: ${
|
|
93
|
+
`);return}let c=a.oldestLastUsedMs!==void 0?` (oldest: ${Rv(Date.now()-a.oldestLastUsedMs)} ago)`:"";process.stdout.write(`Collected ${a.deleted} of ${a.considered} ${d} session(s)${c}.
|
|
74
94
|
`),a.failed>0&&process.stdout.write(` ${a.failed} failed (see daemon log).
|
|
75
95
|
`),a.deferred>0&&process.stdout.write(` ${a.deferred} deferred \u2014 re-run \`hydra sessions collect\` to drain.
|
|
76
|
-
`)}function
|
|
96
|
+
`)}function Rv(t){let e=t/864e5;if(e>=1)return`${e.toFixed(e>=10?0:1)}d`;let n=t/(3600*1e3);return n>=1?`${n.toFixed(n>=10?0:1)}h`:`${(t/(60*1e3)).toFixed(0)}m`}async function Ip(t,e,n){t||(process.stderr.write(`Usage: hydra-acp sessions export <session-id> [--out <file>] [--tools inline|summary]
|
|
77
97
|
`),process.exit(2));let s=await Z(),r=await pe(),i=ge(s.daemon.host,s.daemon.port,!!s.daemon.tls),o=n==="summary"?"?tools=summary":"",a=await fetch(`${i}/v1/sessions/${encodeURIComponent(t)}/export${o}`,{headers:{Authorization:`Bearer ${r}`}});if(!a.ok){let l=await a.text().catch(()=>"");process.stderr.write(`Daemon returned HTTP ${a.status}: ${l}
|
|
78
98
|
`),process.exit(1)}let d=await a.text();if(!e){process.stdout.write(d),d.endsWith(`
|
|
79
99
|
`)||process.stdout.write(`
|
|
80
|
-
`);return}let c=e==="."
|
|
81
|
-
`)}async function
|
|
82
|
-
`),process.exit(2));let n,s,r=await
|
|
100
|
+
`);return}let c=e==="."?_v(a,t):e;await Rt.mkdir(Tt.dirname(Tt.resolve(c)),{recursive:!0}),await Rt.writeFile(c,d,{encoding:"utf8",mode:384}),process.stdout.write(`Wrote ${c}
|
|
101
|
+
`)}async function Sp(t,e){t||(process.stderr.write(`Usage: hydra-acp sessions transcript <session-id>|<file> [--out <file>|.]
|
|
102
|
+
`),process.exit(2));let n,s,r=await Tv(t);if(r!==null){let o=Ev(r.raw);n=To(o);let a=new Date().toISOString().replace(/[:.]/g,"-");s=`${Tt.basename(t,Tt.extname(t))}-${a}.md`}else{let o=await Z(),a=await pe(),d=ge(o.daemon.host,o.daemon.port,!!o.daemon.tls),c=await fetch(`${d}/v1/sessions/${encodeURIComponent(t)}/transcript`,{headers:{Authorization:`Bearer ${a}`}});if(!c.ok){let f=await c.text().catch(()=>"");process.stderr.write(`Daemon returned HTTP ${c.status}: ${f}
|
|
83
103
|
`),process.exit(1)}n=await c.text();let l=new Date().toISOString().replace(/[:.]/g,"-");s=`hydra-${t}-${l}.md`}if(!e){process.stdout.write(n),n.endsWith(`
|
|
84
104
|
`)||process.stdout.write(`
|
|
85
105
|
`);return}let i=e==="."?s:e;await Rt.mkdir(Tt.dirname(Tt.resolve(i)),{recursive:!0}),await Rt.writeFile(i,n,{encoding:"utf8",mode:384}),process.stdout.write(`Wrote ${i}
|
|
86
|
-
`)}async function
|
|
87
|
-
`),process.exit(1)}}function
|
|
88
|
-
`),process.exit(1)}}async function
|
|
106
|
+
`)}async function Tv(t){try{if(!(await Rt.stat(t)).isFile())return null}catch{return null}let e=await Rt.readFile(t,"utf8");try{return{raw:JSON.parse(e)}}catch(n){process.stderr.write(`Failed to parse bundle file: ${n.message}
|
|
107
|
+
`),process.exit(1)}}function Ev(t){try{return Bt(t)}catch(e){process.stderr.write(`Not a valid bundle: ${e.message}
|
|
108
|
+
`),process.exit(1)}}async function kp(t,e={}){t||(process.stderr.write(`Usage: hydra-acp sessions import <file>|- [--replace] [--cwd <path>] [--info]
|
|
89
109
|
`),process.exit(2));let n;if(e.cwd!==void 0){let l=Tt.resolve(e.cwd);try{(await Rt.stat(l)).isDirectory()||(process.stderr.write(`--cwd ${l} is not a directory
|
|
90
110
|
`),process.exit(1))}catch{process.stderr.write(`--cwd ${l} does not exist
|
|
91
|
-
`),process.exit(1)}n=l}let s;t==="-"?s=await
|
|
92
|
-
`),process.exit(1)}if(e.info===!0){let l=await Z();
|
|
111
|
+
`),process.exit(1)}n=l}let s;t==="-"?s=await $v():s=await Rt.readFile(t,"utf8");let r;try{r=JSON.parse(s)}catch(l){process.stderr.write(`Failed to parse bundle: ${l.message}
|
|
112
|
+
`),process.exit(1)}if(e.info===!0){let l=await Z();Mv(r,l.tui.cwdColumnMaxWidth);return}let i=await Z(),o=await pe(),a=ge(i.daemon.host,i.daemon.port,!!i.daemon.tls),d=await fetch(`${a}/v1/sessions/import`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${o}`},body:JSON.stringify({bundle:r,replace:e.replace===!0,...n!==void 0?{cwd:n}:{}})});if(d.status===409){let l=await d.json().catch(()=>({}));process.stderr.write(`Bundle already imported as ${l.existingSessionId??"unknown"}. Use --replace to overwrite.
|
|
93
113
|
`),process.exit(1)}if(!d.ok){let l=await d.text().catch(()=>"");process.stderr.write(`Daemon returned HTTP ${d.status}: ${l}
|
|
94
114
|
`),process.exit(1)}let c=await d.json();process.stdout.write(c.replaced?`Replaced ${c.sessionId} (from ${c.importedFromSessionId})
|
|
95
115
|
`:`Imported as ${c.sessionId} (from ${c.importedFromSessionId})
|
|
96
|
-
`)}function
|
|
97
|
-
`),process.exit(1)}let s=
|
|
98
|
-
`),process.stdout.write(
|
|
116
|
+
`)}function Pv(t){return{sessionId:t.session.sessionId,cwd:t.session.cwd,agentId:t.session.agentId,currentUsage:t.session.currentUsage,title:t.session.title,importedFromMachine:t.exportedFrom.machine,attachedClients:0,updatedAt:t.session.updatedAt,status:"cold"}}function Mv(t,e){let n;try{n=Bt(t)}catch(c){process.stderr.write(`Not a valid bundle: ${c.message}
|
|
117
|
+
`),process.exit(1)}let s=Pv(n),r=ur(s),i={columns:zo,cwdMaxWidth:e},o=fr([r],i),a=process.stdout.isTTY?process.stdout.columns:void 0;process.stdout.write(Dn(lr,o,a,i)+`
|
|
118
|
+
`),process.stdout.write(Dn(r,o,a,i)+`
|
|
99
119
|
`);let d=n.session.upstreamSessionId??"-";process.stdout.write(`
|
|
100
120
|
lineage: ${n.session.lineageId}
|
|
101
121
|
exported: ${n.exportedAt} from ${n.exportedFrom.machine} (hydra ${n.exportedFrom.hydraVersion})
|
|
@@ -103,80 +123,80 @@ origin session: ${n.session.sessionId}
|
|
|
103
123
|
origin upstream: ${d}
|
|
104
124
|
history entries: ${n.history.length}`+(n.promptHistory?`, prompt history: ${n.promptHistory.length}
|
|
105
125
|
`:`
|
|
106
|
-
`))}async function
|
|
107
|
-
`),process.exit(1)),s=u.sessionId}let{host:r,port:i,isFallback:o}=
|
|
126
|
+
`))}async function $v(){let t=[];for await(let e of process.stdin)t.push(typeof e=="string"?Buffer.from(e):e);return Buffer.concat(t).toString("utf8")}function _v(t,e){let n=t.headers.get("content-disposition");if(n){let r=n.match(/filename="([^"]+)"/);if(r)return r[1]}let s=new Date().toISOString().replace(/[:.]/g,"-");return`hydra-${e}-${s}.hydra`}function ge(t,e,n){return`${n?"https":"http"}://${t}:${e}`}async function xp(t,e={}){let n=await Z(),s;if(t!==void 0&&t.length>0)s=t;else{let c=await Wt(n),l=e.cwd?Tt.resolve(e.cwd):process.cwd(),f=await cn(c,{cwd:l,all:!0}),u=jo(f,l);u||(process.stderr.write(`No sessions found for ${l}.
|
|
127
|
+
`),process.exit(1)),s=u.sessionId}let{host:r,port:i,isFallback:o}=Fv(e.host,n),a=He(s),d=ml({host:r,port:i,sessionId:a});process.stdout.write(d+`
|
|
108
128
|
`),o&&process.stderr.write(`Note: this URL points at loopback (127.0.0.1) and only works from the same machine. Set daemon.publicHost in config.json or pass --host <name> to advertise an externally-reachable hostname.
|
|
109
|
-
`)}function
|
|
110
|
-
`)});let d=new
|
|
111
|
-
`)});let c=new Promise(l=>{o.once("exit",()=>l()),o.once("error",()=>l())});return{stream:d,flush:async()=>{a.writable&&await new Promise(l=>{d.end(()=>l())}),await c}}}function
|
|
112
|
-
`),l=!1,f="",u=[],p=i!==" ",g=(v,b,x=" ")=>{let C={prefix:x,body:v,bodyStyle:b};r!==void 0&&(C.prefixStyle=r),d.push(C)},h=()=>p?(p=!1,i):" ",w=()=>{if(u.length!==0){if(s){let v=
|
|
113
|
-
`),{language:t,theme:
|
|
129
|
+
`)}function Fv(t,e){if(t!==void 0&&t.length>0){let{host:n,port:s}=gp(t,443);return{host:n,port:s,isFallback:!1}}if(e.daemon.publicHost&&e.daemon.publicHost.length>0){let{host:n,port:s}=gp(e.daemon.publicHost,443);return{host:n,port:s,isFallback:!1}}return on(e.daemon.host)?{host:"127.0.0.1",port:e.daemon.port,isFallback:!0}:{host:e.daemon.host,port:e.daemon.port,isFallback:!1}}function gp(t,e){if(t.startsWith("[")){let s=t.indexOf("]");if(s>0){let r=t.slice(1,s),i=t.slice(s+1);if(i.startsWith(":")){let o=Number(i.slice(1));return{host:r,port:Number.isInteger(o)&&o>0?o:e}}return{host:r,port:e}}}let n=t.lastIndexOf(":");if(n>0&&t.indexOf(":")===n){let s=t.slice(0,n),r=Number(t.slice(n+1));if(Number.isInteger(r)&&r>0)return{host:s,port:r}}return{host:t,port:e}}var Hn=V(()=>{"use strict";Ne();mt();Us();Br();Yt();qo();us();xd();Jo()});import{spawn as Ov}from"child_process";import{Writable as Lv}from"stream";function Ko(t={}){let e=t.isTTY??process.stdout.isTTY===!0;if(t.disabled===!0||!e)return{stream:process.stdout,flush:async()=>{}};let n=t.env??process.env,s=Bv(n);if(s===null)return{stream:process.stdout,flush:async()=>{}};let r=t.spawn??Ov,i={...n};i.LESS===void 0&&(i.LESS="FRX");let o=r(s,[],{shell:!0,stdio:["pipe","inherit","inherit"],env:i}),a=o.stdin;if(a===null)return{stream:process.stdout,flush:async()=>{}};a.on("error",l=>{l.code!=="EPIPE"&&process.stderr.write(`pager: ${l.message}
|
|
130
|
+
`)});let d=new Lv({write(l,f,u){if(!a.writable){u();return}a.write(l,g=>{if(g&&g.code!=="EPIPE"){u(g);return}u()})||a.once("drain",()=>{})},final(l){a.writable&&a.end(),l()}});d.on("error",l=>{l.code!=="EPIPE"&&process.stderr.write(`pager: ${l.message}
|
|
131
|
+
`)});let c=new Promise(l=>{o.once("exit",()=>l()),o.once("error",()=>l())});return{stream:d,flush:async()=>{a.writable&&await new Promise(l=>{d.end(()=>l())}),await c}}}function Bv(t){let e=t.HYDRA_ACP_PAGER;if(e!==void 0)return e.length===0?null:e;let n=t.PAGER;return n!==void 0?n.length===0?null:n:"less"}var Ld=V(()=>{"use strict"});import Nv from"chalk";import{highlight as Dv,supportsLanguage as Hv}from"cli-highlight";import Yo from"string-width";function pr(t,e={}){switch(t.kind){case"user-text":{let n=Bd(t.text,"\u258E ","user",void 0,t.sentBy,!0);if(t.attachments&&t.attachments.length>0)for(let s of t.attachments)n.push({prefix:"\u258E ",prefixStyle:"user",body:`\u{1F4CE} ${s.name??"image"}`,bodyStyle:"user",fillRow:!0,iterm2Image:{data:s.data,heightCells:5}});return n}case"agent-text":return Bd(t.text," ","agent");case"agent-thought":return Bd(t.text," ","thought","thought");case"tool-call":case"tool-call-update":return[];case"exit-plan-mode":return[];case"plan":return oI(t,e.maxPlanItems??rI);case"mode-changed":return[{prefix:"\xBB ",prefixStyle:"info",body:`mode: ${t.mode}`,bodyStyle:"info"}];case"model-changed":return[];case"turn-complete":return[];case"usage-update":return[];case"available-commands":case"available-modes":case"config-options":return[];case"session-info":return[];case"unknown":return[]}}function oi(t,e){let n=e?.codeOpen??"^C",s=e?.boldReset??"^:",r=e?.codeReset??"^:",i=t.replace(/\^/g,"^^");return i=i.replace(/\*\*(.+?)\*\*/g,`^+$1${s}`),i=i.replace(/`([^`]+)`/g,`${n}$1${r}`),i}function Cp(t){switch(t){case"heading-1":return{codeOpen:"^C",boldReset:"^+^Y",codeReset:"^+^Y"};case"heading-2":return{codeOpen:"^Y",boldReset:"^+^C",codeReset:"^+^C"};default:return{codeOpen:"^C",boldReset:"^:^+",codeReset:"^:^+"}}}function Rp(t,e){let{proseStyle:n,highlightCode:s,prefixStyle:r,firstPrefix:i=" ",inlineOpts:o,maxWidth:a}=e,d=[],c=t.replace(/^\s+/,"").split(`
|
|
132
|
+
`),l=!1,f="",u=[],p=i!==" ",g=(v,b,x=" ")=>{let C={prefix:x,body:v,bodyStyle:b};r!==void 0&&(C.prefixStyle=r),d.push(C)},h=()=>p?(p=!1,i):" ",w=()=>{if(u.length!==0){if(s){let v=Qv(f,u);for(let b of v){let x={prefix:" ",body:b.body,bodyStyle:"code",fillRow:!0};r!==void 0&&(x.prefixStyle=r),b.ansi&&(x.ansi=!0),d.push(x)}}else for(let v of u)g(v.replace(/\^/g,"^^"),n);u=[],f=""}};for(let v=0;v<c.length;v++){let b=c[v],x=b.match(/^\s*```\s*(\w*)\s*$/);if(x){l?(w(),l=!1):(l=!0,f=x[1]??"");continue}if(l){u.push(b);continue}let C=b.match(/^(#{1,6})\s+(.*)$/);if(C){let N=C[1].length,F=C[2]??"",U=s?N===1?"heading-1":N===2?"heading-2":"heading-3":n,J=s?Cp(U):o;g(oi(F,J),U,h());continue}let O=c[v+1];if(b.includes("|")&&O!==void 0&&Uv(O)&&ai(b).length===ai(O).length){let N=ai(b),F=[],U=v+2;for(;U<c.length&&c[U].includes("|");)F.push(ai(c[U])),U++;let J=Vv(N,F,a);for(let ie of J)r!==void 0&&(ie.prefixStyle=r),d.push(ie);v=U-1;continue}let q=b.match(/^(\s*)[-*+]\s+(.*)$/);if(q){let N=q[1]??"",F=q[2]??"";g(`${N}\u2022 ${oi(F,o)}`,n,h());continue}let W=b.match(/^(\s*)(\d+)\.\s+(.*)$/);if(W){let N=W[1]??"",F=W[2]??"",U=W[3]??"";g(`${N}${F}. ${oi(U,o)}`,n,h());continue}let Q=b.trim()==="";g(oi(b,o),n,Q?" ":h())}for(l&&w();d.length>0&&d[d.length-1].body==="";)d.pop();return d}function mr(t,e){return Rp(t,{proseStyle:"agent",highlightCode:!0,maxWidth:e?.maxWidth})}function Nd(t){return Rp(t,{proseStyle:"thought",highlightCode:!1,prefixStyle:"thought",firstPrefix:" ",inlineOpts:{codeOpen:"^c",boldReset:"^-",codeReset:"^K"}})}function ai(t){let e=t.trim();return e.startsWith("|")&&(e=e.slice(1)),e.endsWith("|")&&(e=e.slice(0,-1)),e.split("|").map(n=>n.trim())}function Uv(t){if(!t.includes("|"))return!1;let e=ai(t);return e.length===0?!1:e.every(n=>/^:?-+:?$/.test(n))}function Vo(t){let e=t.replace(/\*\*(.+?)\*\*/g,"$1").replace(/`([^`]+)`/g,"$1");return Yo(e)}function Wv(t){let e=[],n=0;for(;n<t.length;){let s=t[n];if(s===" "||s===" "){let o=n;for(;o<t.length&&(t[o]===" "||t[o]===" ");)o++;let a=t.slice(n,o);e.push({text:a,isWS:!0,width:Yo(a)}),n=o;continue}let r="",i=n;for(;i<t.length;){let o=t[i];if(o===" "||o===" ")break;if(t[i]==="*"&&t[i+1]==="*"){let a=t.indexOf("**",i+2);a===-1?(r+="**",i+=2):(r+=t.slice(i,a+2),i=a+2);continue}if(o==="`"){let a=t.indexOf("`",i+1);a===-1?(r+="`",i+=1):(r+=t.slice(i,a+1),i=a+1);continue}r+=o,i+=1}e.push({text:r,isWS:!1,width:Vo(r)}),n=i}return e}function zv(t,e){let n=[],s="",r=0;for(let i of t){let o=Yo(i);r>0&&r+o>e?(n.push(s),s=i,r=o):(s+=i,r+=o)}return s.length>0&&n.push(s),n}function Jv(t,e){if(e<=0)return t.length===0?[""]:[t.map(o=>o.text).join("")];let n=[],s="",r=0,i=()=>{n.push(s.replace(/[ \t]+$/,"")),s="",r=0};for(let o of t){if(o.isWS){if(r===0)continue;s+=o.text,r+=o.width;continue}if(o.width>e){if(r>0&&i(),o.text.includes("**")||o.text.includes("`"))n.push(o.text);else{let d=zv(o.text,e);for(let l=0;l<d.length-1;l++)n.push(d[l]);let c=d[d.length-1]??"";s=c,r=Yo(c)}continue}if(r===0){s=o.text,r=o.width;continue}r+o.width>e?(i(),s=o.text,r=o.width):(s+=o.text,r+=o.width)}return(s.length>0||n.length===0)&&i(),n}function Kv(t,e){let n=t.length;if(t.reduce((l,f)=>l+f,0)<=e)return t.slice();let r=t.map(l=>Math.min(l,Tp)),i=r.reduce((l,f)=>l+f,0);if(i>=e)return r;let o=e-i,a=t.map((l,f)=>({i:f,slack:Math.max(0,l-r[f])})).filter(l=>l.slack>0),d=a.reduce((l,f)=>l+f.slack,0);if(d===0)return r;for(let l of a){let f=Math.floor(o*l.slack/d);r[l.i]=r[l.i]+Math.min(f,l.slack)}i=r.reduce((l,f)=>l+f,0);let c=e-i;for(;c>0;){let l=-1,f=0;for(let u=0;u<n;u++){let p=t[u]-r[u];p>f&&(f=p,l=u)}if(l<0)break;r[l]=r[l]+1,c--}return r}function Vv(t,e,n){let s=t.length,r=new Array(s).fill(0);for(let c=0;c<s;c++)r[c]=Vo(t[c]??"");for(let c of e)for(let l=0;l<s;l++){let f=c[l]??"",u=Vo(f);u>r[l]&&(r[l]=u)}let i=r.slice();if(n!==void 0){let c=Math.max(s*Tp,n-jv-(s-1)*qv);i=Kv(r,c)}let o=(c,l,f)=>{let u=[],p=1;for(let h=0;h<s;h++){let w=c[h]??"",v=i[h],b=Jv(Wv(w),v);u.push(b),b.length>p&&(p=b.length)}let g=[];for(let h=0;h<p;h++){let w=[];for(let v=0;v<s;v++){let b=u[v][h]??"",x=i[v],C=Vo(b),O=oi(b,f);w.push(O+" ".repeat(Math.max(0,x-C)))}g.push({prefix:" ",body:w.join(" \u2502 "),bodyStyle:l})}return g},a=[];a.push(...o(t,"heading-3",Cp("heading-3")));let d=[];for(let c=0;c<s;c++)d.push("\u2500".repeat(i[c]));a.push({prefix:" ",body:d.join("\u2500\u253C\u2500"),bodyStyle:"dim"});for(let c of e)a.push(...o(c,"agent"));return a}function Qv(t,e){if(t.length===0||!Hv(t))return e.map(r=>({body:r,ansi:!1}));let n;try{n=Dv(e.join(`
|
|
133
|
+
`),{language:t,theme:Yv,ignoreIllegals:!0})}catch{return e.map(r=>({body:r,ansi:!1}))}n=n.replace(/\x1b\[39m/g,"\x1B[37m");let s=n.split(`
|
|
114
134
|
`);return s.length!==e.length?e.map(r=>({body:r,ansi:!1})):s.map((r,i)=>({body:r,ansi:r!==e[i]}))}function Bd(t,e,n,s,r,i){let o=t.replace(/^\s+/,"").split(`
|
|
115
|
-
`),a=[];r&&a.push({prefix:"\u21B3 ",prefixStyle:"dim",body:`from ${r}`,bodyStyle:"dim"});for(let d of o){let c={prefix:e,prefixStyle:s??n,body:d,bodyStyle:n};i&&(c.fillRow=!0),a.push(c)}return a}function
|
|
135
|
+
`),a=[];r&&a.push({prefix:"\u21B3 ",prefixStyle:"dim",body:`from ${r}`,bodyStyle:"dim"});for(let d of o){let c={prefix:e,prefixStyle:s??n,body:d,bodyStyle:n};i&&(c.fillRow=!0),a.push(c)}return a}function Gv(t){return t<1024?`${t} B`:t<1024*1024?`${Math.round(t/1024)} KB`:`${(t/(1024*1024)).toFixed(1)} MB`}function Gt(t){let e=Math.floor(t/1e3);if(e<60)return`${e}s`;let n=Math.floor(e/60),s=e%60;if(n<60)return s===0?`${n}m`:`${n}m ${s}s`;let r=Math.floor(n/60),i=n%60;return i===0?`${r}h`:`${r}h ${i}m`}function Ep(t,e=Date.now()){let n=t.initialTitle,s=t.latestTitle,r=n.toLowerCase(),i=s.toLowerCase(),o;if(s===n||i.includes(r)?o=s:r.includes(i)?o=n:o=`${n} \xB7 ${s}`,t.detail){let d=t.detail,c=o.toLowerCase(),l=d.toLowerCase();(l.startsWith(`${c} `)||l.startsWith(`${c} `))&&(d=d.slice(o.length).trimStart()),d.length>0&&!o.includes(d)&&(o=`${o} \xB7 ${d}`)}if(t.startedAt!==void 0){let d=t.endedAt??e;o=`${o} \xB7 ${Gt(d-t.startedAt)}`}let a=[{prefix:` ${tI(t.status)} `,prefixStyle:nI(t.status),body:o,bodyStyle:aI(t.status)}];return t.status==="failed"&&t.errorText&&a.push({prefix:" ",body:ke(t.errorText),bodyStyle:"tool-status-fail"}),a}function Mp(t){Pp=t>=0?t:0}function Dd(t,e,n={}){let s=[],r=t.oldRef!==void 0||t.newRef!==void 0,i;if(r){let c=(t.oldRef?.bytes??0)+(t.newRef?.bytes??0);i=` (~${Gv(c)})`}else{let c=Zv(t),l=[];c.added>0&&l.push(`+${c.added}`),c.removed>0&&l.push(`-${c.removed}`),i=l.length>0?` (${l.join(" ")})`:""}let o=c=>({prefix:" ",body:`${c?"\u25BE":"\u25B8"} Edited ${ke(Be(t.path))}${i}`,bodyStyle:"dim"});if(e==="edit")return t.path&&s.push(o(!1)),s;if(r)return t.path&&(s.push(o(!0)),s.push(n.deferredStatus==="error"?{prefix:" ",body:"\u26A0 failed to load diff",bodyStyle:"tool-status-fail"}:{prefix:" ",body:"\u22EF fetching diff\u2026",bodyStyle:"dim"}),s.unshift({body:""})),s;let a=Hd(t,{maxLines:1/0});if(a.length===0)return t.path&&s.push(o(!1)),s;t.path&&s.push(o(!0));let d="```diff\n"+a+"\n```";return s.push(...mr(d)),s.length>0&&s.unshift({body:""}),s}function $p(t){let e=ct(t.oldText).split(`
|
|
116
136
|
`),n=ct(t.newText).split(`
|
|
117
|
-
`);return e.length>0&&e[e.length-1]===""&&e.pop(),n.length>0&&n[n.length-1]===""&&n.pop(),{oldLines:e,newLines:n}}function
|
|
118
|
-
`)}function
|
|
137
|
+
`);return e.length>0&&e[e.length-1]===""&&e.pop(),n.length>0&&n[n.length-1]===""&&n.pop(),{oldLines:e,newLines:n}}function Zv(t){let{oldLines:e,newLines:n}=$p(t),s=0,r=0;for(let i of _p(e,n))i.op==="+"?s++:i.op==="-"&&r++;return{added:s,removed:r}}function Ap(t){return t.op==="="?` ${t.text}`:t.op==="-"?`- ${t.text}`:`+ ${t.text}`}function Hd(t,e={}){let n=e.maxLines??Xv,s=e.contextLines??Pp,{oldLines:r,newLines:i}=$p(t),o=_p(r,i),a=[];if(Number.isFinite(s)){if(!o.some(u=>u.op!=="="))return"";let l=new Array(o.length).fill(!1);for(let u=0;u<o.length;u++)if(o[u].op!=="="){let p=Math.max(0,u-s),g=Math.min(o.length-1,u+s);for(let h=p;h<=g;h++)l[h]=!0}let f=0;for(;f<o.length;){if(l[f]){a.push(Ap(o[f])),f++;continue}let u=f;for(;u<o.length&&!l[u];)u++;let p=u-f;a.push(` \u22EF ${p} unchanged line${p===1?"":"s"}`),f=u}}else for(let c of o)a.push(Ap(c));let d=[];for(let c=0;c<a.length;c++){if(d.length>=n-1&&c<a.length-1){let f=a.length-c;d.push(`\u2026 ${f} more line${f===1?"":"s"}`);break}d.push(a[c])}return d.join(`
|
|
138
|
+
`)}function _p(t,e){let n=0,s=Math.min(t.length,e.length);for(;n<s&&t[n]===e[n];)n++;let r=t.length,i=e.length;for(;r>n&&i>n&&t[r-1]===e[i-1];)r--,i--;let o=[];for(let a=0;a<n;a++)o.push({op:"=",text:t[a]});o.push(...eI(t.slice(n,r),e.slice(n,i)));for(let a=r;a<t.length;a++)o.push({op:"=",text:t[a]});return o}function eI(t,e){let n=t.length,s=e.length;if(n===0||s===0){let d=[];for(let c of t)d.push({op:"-",text:c});for(let c of e)d.push({op:"+",text:c});return d}let r=Array.from({length:n+1},()=>new Array(s+1).fill(0));for(let d=n-1;d>=0;d--)for(let c=s-1;c>=0;c--)t[d]===e[c]?r[d][c]=r[d+1][c+1]+1:r[d][c]=Math.max(r[d+1][c],r[d][c+1]);let i=[],o=0,a=0;for(;o<n&&a<s;)t[o]===e[a]?(i.push({op:"=",text:t[o]}),o++,a++):r[o+1][a]>=r[o][a+1]?(i.push({op:"-",text:t[o]}),o++):(i.push({op:"+",text:e[a]}),a++);for(;o<n;)i.push({op:"-",text:t[o]}),o++;for(;a<s;)i.push({op:"+",text:e[a]}),a++;return i}function Fp(t){switch(t){case"completed":case"succeeded":case"ok":case"failed":case"error":case"rejected":case"cancelled":return!0;default:return!1}}function tI(t){switch(t){case"completed":case"succeeded":case"ok":return"\u2713";case"failed":case"error":return"\u2717";case"rejected":return"\u2298";case"cancelled":return"\u229D";default:return"\u25D0"}}function nI(t){switch(t){case"completed":case"succeeded":case"ok":return"tool-status-ok";case"failed":case"error":case"rejected":return"tool-status-fail";case"cancelled":return"tool-status-cancelled";default:return"tool-status-running"}}function Op(t){let e=[{prefix:"\u25A3 ",prefixStyle:"plan",body:"Plan",bodyStyle:"plan"}];e.push(...mr(t.plan));let n=t.status;if(n!==void 0){let s=sI(n);s!==null&&e.push(s)}return e}function sI(t){switch(t){case"completed":case"succeeded":case"ok":return{prefix:" ",body:"\u2713 Approved",bodyStyle:"tool-status-ok"};case"failed":case"error":case"rejected":return{prefix:" ",body:"\u2717 Rejected",bodyStyle:"tool-status-fail"};case"cancelled":return{prefix:" ",body:"\u229D Cancelled",bodyStyle:"tool-status-cancelled"};case"pending":case"in_progress":case"running":case"updated":return{prefix:" ",body:"awaiting approval\u2026",bodyStyle:"dim"};default:return null}}function iI(t,e){let n=t.length;if(e<=0||n<=e)return{start:0,end:n};let s=t.findIndex(c=>(c.status??"pending")==="in_progress"),r=t.findIndex(c=>(c.status??"pending")==="pending"),i=s>=0?s:r>=0?r:n-1,o=Math.floor((e-1)/2),a=Math.max(0,i-o),d=Math.min(n,a+e);return d-a<e&&(a=Math.max(0,d-e)),{start:a,end:d}}function oI(t,e){let n=t.stopped===!0,r=t.amended===!0?"tool-status-cancelled":"tool-status-fail",o=t.entries.every(p=>(p.status??"pending")==="completed")?"plan-done":n?r:"plan",a=t.entries.length,{start:d,end:c}=iI(t.entries,e),l=c-d<a,f="Plan";if(l){let p=0;for(let h of t.entries)(h.status??"pending")==="completed"&&(p+=1);let g=a-p;f=g===0?`Plan \xB7 ${p} done`:`Plan \xB7 ${p} done \xB7 ${g} left`}let u=[{prefix:"\u25A3 ",prefixStyle:o,body:f,bodyStyle:o}];for(let p=d;p<c;p++){let g=t.entries[p];if(!g)continue;let h=g.status??"pending",w=h==="completed"?"[x]":h==="in_progress"?"[~]":"[ ]",v=h==="completed"?"plan-done":h==="in_progress"?n?"plan-pending":"plan":"plan-pending",b=g.content.replace(/^\d+\/\d+\s+/,"").replace(/\s*\(?\d+\/\d+\)?\s*$/,"");u.push({prefix:" ",body:`${w} ${b}`,bodyStyle:v})}return u}function aI(t){switch(t){case"completed":case"succeeded":case"ok":return"tool-status-ok";case"failed":case"error":case"rejected":return"tool-status-fail";case"in_progress":case"running":case"updated":return"tool-status-running";case"cancelled":return"tool-status-cancelled";default:return"tool-status-pending"}}var Tp,jv,qv,Fe,Yv,Xv,Pp,rI,di=V(()=>{"use strict";ue();ms();Tp=6,jv=2,qv=3;Fe=new Nv.Instance({level:3}),Yv={keyword:Fe.blueBright,built_in:Fe.cyan,type:Fe.cyanBright,literal:Fe.blue,number:Fe.greenBright,string:Fe.yellow,regexp:Fe.red,comment:Fe.gray,function:Fe.yellow,title:Fe.yellow,class:Fe.yellowBright,attr:Fe.cyan,attribute:Fe.cyan,variable:Fe.white,params:Fe.white,meta:Fe.magenta,symbol:Fe.magenta,addition:Fe.greenBright,deletion:Fe.redBright,section:Fe.cyan,tag:Fe.cyan,name:Fe.cyanBright};Xv=40,Pp=Number.POSITIVE_INFINITY;rI=5});import{highlight as dI,supportsLanguage as cI}from"cli-highlight";async function Bp(t,e={}){t||(process.stderr.write(`Usage: hydra-acp session diff <session-id> [--json] [--no-color]
|
|
119
139
|
`),process.exit(2));let n=await Z(),s=await pe(),r=ge(n.daemon.host,n.daemon.port,!!n.daemon.tls),i=new URL(`${r}/v1/sessions/${encodeURIComponent(t)}/diff`);e.fold===!0&&i.searchParams.set("fold","true");let o=await fetch(i.toString(),{headers:{Authorization:`Bearer ${s}`}}),a;if(o.ok)a=await o.json();else if(o.status===404){let f=await fetch(`${r}/v1/sessions/${encodeURIComponent(t)}/export`,{headers:{Authorization:`Bearer ${s}`}});if(!f.ok){let h=await f.text().catch(()=>"");process.stderr.write(`Daemon returned HTTP ${f.status}: ${h}
|
|
120
140
|
`),process.exit(1)}let u=await f.json(),p;try{p=Bt(u)}catch(h){process.stderr.write(`Failed to decode session bundle: ${h.message}
|
|
121
141
|
`),process.exit(1)}let g=tr(p.history);a=e.fold===!0?g.map(h=>({...h,hunks:nr(h.hunks)})):g}else{let f=await o.text().catch(()=>"");process.stderr.write(`Daemon returned HTTP ${o.status}: ${f}
|
|
122
142
|
`),process.exit(1)}if(e.json){process.stdout.write(JSON.stringify(a,null,2)+`
|
|
123
143
|
`);return}let d=Ko({disabled:e.noPager===!0}),c=process.stdout.isTTY===!0,l=!e.noColor&&c;d.stream.write(Ud(a,l)),await d.flush()}function Ud(t,e){if(t.length===0)return`No file edits found in this session.
|
|
124
|
-
`;let n=[],s=[...t].sort((r,i)=>r.path.localeCompare(i.path));for(let r of s){let i=
|
|
125
|
-
`:n.join("")}function
|
|
126
|
-
`))if(e.startsWith("+ ")||e.startsWith("- "))return!0;return!1}function
|
|
144
|
+
`;let n=[],s=[...t].sort((r,i)=>r.path.localeCompare(i.path));for(let r of s){let i=fI(r,e);i!==null&&n.push(i)}return n.length===0?`No file edits found in this session.
|
|
145
|
+
`:n.join("")}function lI(t){let e=[];for(let n of t.hunks){let s=Hd(n,{maxLines:1/0});uI(s)&&e.push({body:s,oldCount:Lp(n.oldText),newCount:Lp(n.newText)})}return e}function uI(t){if(t.length===0)return!1;for(let e of t.split(`
|
|
146
|
+
`))if(e.startsWith("+ ")||e.startsWith("- "))return!0;return!1}function fI(t,e){let n=lI(t);if(n.length===0)return null;let s=[];s.push(`diff --hydra a/${t.path} b/${t.path}`),t.created?(s.push("new file"),s.push("--- /dev/null"),s.push(`+++ b/${t.path}`)):(s.push(`--- a/${t.path}`),s.push(`+++ b/${t.path}`));let r=n.length;n.forEach((o,a)=>{let d=o.oldCount===0?0:1,c=o.newCount===0?0:1,l=r>1?` edit ${a+1} of ${r}`:"";s.push(`@@ -${d},${o.oldCount} +${c},${o.newCount} @@${l}`),s.push(o.body)});let i=s.join(`
|
|
127
147
|
`)+`
|
|
128
148
|
|
|
129
|
-
`;return!e||!
|
|
130
|
-
`);return e[e.length-1]===""&&e.pop(),e.length}var jd=V(()=>{"use strict";Ne();mt();
|
|
149
|
+
`;return!e||!cI("diff")?i:dI(i,{language:"diff"})}function Lp(t){if(t.length===0)return 0;let e=t.split(`
|
|
150
|
+
`);return e[e.length-1]===""&&e.pop(),e.length}var jd=V(()=>{"use strict";Ne();mt();us();Ro();di();Ld();Hn()});import*as IE from"fs/promises";async function Np(t,e={}){t||(process.stderr.write(`Usage: hydra-acp sessions info <session-id> [--verbose] [--json] [--diff] [--fold] [--no-color] [--no-pager]
|
|
131
151
|
`),process.exit(2));let n=await Z(),s=await pe(),r=ge(n.daemon.host,n.daemon.port,!!n.daemon.tls),i=await fetch(`${r}/v1/sessions`,{headers:{Authorization:`Bearer ${s}`}});i.ok||(process.stderr.write(`Daemon returned HTTP ${i.status}
|
|
132
152
|
`),process.exit(1));let a=(await i.json()).sessions.find(w=>w.sessionId===t)?.status,d=await fetch(`${r}/v1/sessions/${encodeURIComponent(t)}/export`,{headers:{Authorization:`Bearer ${s}`}});if(!d.ok){let w=await d.text().catch(()=>"");process.stderr.write(`Daemon returned HTTP ${d.status}: ${w}
|
|
133
153
|
`),process.exit(1)}let c=await d.json(),l;try{l=Bt(c)}catch(w){process.stderr.write(`Failed to decode session bundle: ${w.message}
|
|
134
154
|
`),process.exit(1)}let f=zd(l,a??"cold"),u=e.diff===!0,p=null;if(u){let w=tr(l.history);p=e.fold===!0?w.map(v=>({...v,hunks:nr(v.hunks)})):w}if(e.json){let w={...f};p!==null&&(w.diff=p),process.stdout.write(JSON.stringify(w,null,2)+`
|
|
135
155
|
`);return}let g=process.stdout.isTTY===!0,h=!e.noColor&&g;if(u){let w=Ko({disabled:e.noPager===!0});w.stream.write(Qo(f,e.verbose===!0)),w.stream.write(`
|
|
136
|
-
`),w.stream.write(Ud(p??[],h)),await w.flush();return}process.stdout.write(Qo(f,e.verbose===!0))}function zd(t,e){let n=t.session,s=t.history,r=
|
|
156
|
+
`),w.stream.write(Ud(p??[],h)),await w.flush();return}process.stdout.write(Qo(f,e.verbose===!0))}function zd(t,e){let n=t.session,s=t.history,r=Mu(s),i=ad(s),o=dd(s),a=n.currentUsage,d=Date.parse(n.createdAt),c=Date.parse(n.updatedAt),l=Number.isFinite(d)&&Number.isFinite(c)?c-d:null;return{sessionId:n.sessionId,...n.upstreamSessionId!==void 0?{upstreamSessionId:n.upstreamSessionId}:{},...n.title!==void 0?{title:n.title}:{},cwd:n.cwd,agentId:n.agentId,...n.currentModel!==void 0?{currentModel:n.currentModel}:{},status:e,createdAt:n.createdAt,updatedAt:n.updatedAt,synopsis:n.synopsis??null,summarizedThroughEntry:n.summarizedThroughEntry??null,turns:r,tools:i,files:o,cost:{amount:a?.costAmount??null,currency:a?.costCurrency??null,cumulative:a?.cumulativeCost??null,inputTokens:a?.used??null,outputTokens:a?.size??null},duration:{totalMs:l},historyEntries:s.length}}function Qo(t,e){let n=[],s=a=>a.padEnd(14);n.push(`${s("Session:")}${t.sessionId}`),t.upstreamSessionId&&n.push(`${s("Upstream:")}${t.upstreamSessionId}`),t.title&&n.push(`${s("Title:")}${t.title}`),n.push(`${s("Cwd:")}${t.cwd}`);let r=t.currentModel?` \xB7 ${t.currentModel}`:"";n.push(`${s("Agent:")}${t.agentId}${r}`),n.push(`${s("Status:")}${t.status}`),n.push(`${s("Created:")}${t.createdAt}`),n.push(`${s("Last active:")}${t.updatedAt}`),t.duration.totalMs!==null&&n.push(`${s("Duration:")}${mI(t.duration.totalMs)}`),n.push(`${s("Turns:")}${t.turns}`);let i=[];if(t.cost.amount!==null){let a=t.cost.currency??"USD";i.push(`${a} ${t.cost.amount.toFixed(4)}`)}else if(t.cost.cumulative!==null){let a=t.cost.currency??"USD";i.push(`${a} ${t.cost.cumulative.toFixed(4)} (cumulative)`)}if(t.cost.inputTokens!==null||t.cost.outputTokens!==null){let a=[];t.cost.inputTokens!==null&&a.push(`${t.cost.inputTokens.toLocaleString()} in`),t.cost.outputTokens!==null&&a.push(`${t.cost.outputTokens.toLocaleString()} out`),i.push(a.join(" / "))}if(i.length>0&&n.push(`${s("Cost:")}${i.join(" | ")}`),t.synopsis){n.push(""),n.push("Synopsis:");let a=" ",d=c=>c.padEnd(22);if(t.synopsis.goal&&n.push(`${a}${d("Goal:")}${t.synopsis.goal}`),t.synopsis.outcome&&n.push(`${a}${d("Outcome:")}${t.synopsis.outcome}`),t.synopsis.rejected_approaches&&t.synopsis.rejected_approaches.length>0){n.push(`${a}${d("Rejected approaches:")}`);for(let c of t.synopsis.rejected_approaches)n.push(`${a} - ${c}`)}if(t.synopsis.open_threads&&t.synopsis.open_threads.length>0){n.push(`${a}${d("Open threads:")}`);for(let c of t.synopsis.open_threads)n.push(`${a} - ${c}`)}}else n.push(""),n.push("Synopsis: (none yet \u2014 generated on idle-close or daemon shutdown)");if(t.tools.length>0){n.push("");let a=t.tools.reduce((l,f)=>l+f.count,0);n.push(`Tools (${a} calls):`);let d=e?t.tools:t.tools.slice(0,qd),c=Math.max(...d.map(l=>l.name.length),4);for(let l of d)n.push(` ${l.name.padEnd(c)} ${l.count}`);!e&&t.tools.length>qd&&n.push(` ... ${t.tools.length-qd} more (use --verbose to see all)`)}let o=e?t.files:t.files.map(a=>{let d=a.byTool.filter(l=>pI.has(l.name)),c=d.reduce((l,f)=>l+f.count,0);return{path:a.path,count:c,byTool:d}}).filter(a=>a.count>0);if(o.length>0){n.push("");let a=e?"Files touched":"Files edited";n.push(`${a} (${o.length}):`);let d=e?o:o.slice(0,Wd),c=Math.max(...d.map(l=>l.path.length),4);for(let l of d)if(e){let f=l.byTool.map(u=>`${u.name}\xD7${u.count}`).join(", ");n.push(` ${l.path.padEnd(c)} ${l.count} (${f})`)}else n.push(` ${l.path.padEnd(c)} ${l.count}`);!e&&o.length>Wd&&n.push(` ... ${o.length-Wd} more (use --verbose to see all)`)}return n.join(`
|
|
137
157
|
`)+`
|
|
138
|
-
`}function
|
|
139
|
-
`)}}});function
|
|
140
|
-
`).length;if(this.collapsePastes&&n>10){let s=this.nextPasteId++;this.pastes.set(s,e.text),this.insertText(
|
|
141
|
-
`)}expandPastes(e){return e.replace(
|
|
158
|
+
`}function mI(t){if(t<0)return"0s";let e=Math.floor(t/1e3),n=Math.floor(e/86400),s=Math.floor(e%86400/3600),r=Math.floor(e%3600/60),i=e%60,o=[];return n>0&&o.push(`${n}d`),s>0&&o.push(`${s}h`),r>0&&o.push(`${r}m`),(o.length===0||i>0)&&o.push(`${i}s`),o.join(" ")}var qd,Wd,pI,Jd=V(()=>{"use strict";Ne();mt();us();cd();Ro();Ld();jd();Hn();qd=10,Wd=15,pI=new Set(["Edit","MultiEdit","Write","NotebookEdit"])});import{setTimeout as AI}from"timers/promises";import{WebSocket as CI}from"ws";function MI(t){return!("method"in t)&&"id"in t&&t.id!==void 0}async function $I(t,e){return new Promise((n,s)=>{let r=new CI(t,e),i=()=>{r.off("error",o),n(rr(r))},o=a=>{r.off("open",i),s(a)};r.once("open",i),r.once("error",o)})}var RI,TI,EI,PI,yr,Zd=V(()=>{"use strict";$o();dt();RI=200,TI=5e3,EI=2,PI=60,yr=class{constructor(e){this.opts=e}opts;current;outboundQueue=[];messageHandlers=[];closeHandlers=[];destroyed=!1;firstConnect=!0;reconnectInFlight;connectGate;releaseConnectGate;pendingRequests=new Map;async start(){await this.connectWithRetry()}onMessage(e){this.messageHandlers.push(e)}onClose(e){this.closeHandlers.push(e)}async send(e){if(this.destroyed)throw new Error("resilient ws stream is destroyed");if(this.connectGate||!this.current){this.outboundQueue.push(e);return}try{await this.current.send(e)}catch(n){this.outboundQueue.push(e),this.scheduleReconnect(n)}}async request(e){if(this.destroyed)throw new Error("resilient ws stream is destroyed");if(!this.current)throw new Error("resilient ws stream not connected");let n=e.id,s=new Promise((r,i)=>{this.pendingRequests.set(n,{resolve:r,reject:i})});try{await this.current.send(e)}catch(r){throw this.pendingRequests.delete(n),r}return s}async close(){this.destroyed=!0,this.current&&await this.current.close().catch(()=>{});for(let e of this.closeHandlers)e()}async connectWithRetry(){let e=0,n=RI;for(;!this.destroyed;)try{let s=await $I(this.opts.url,this.opts.subprotocols);this.bindStream(s);let r=this.firstConnect;this.firstConnect=!1,this.connectGate=new Promise(i=>{this.releaseConnectGate=i});try{if(this.opts.onConnect)try{await this.opts.onConnect(r)}catch(i){this.log(`hydra-acp: post-connect handler failed: ${i.message}`)}}finally{this.releaseConnectGate?.(),this.releaseConnectGate=void 0,this.connectGate=void 0}await this.flushQueue();return}catch(s){if(e+=1,this.opts.onConnectFailure&&this.opts.onConnectFailure(s),e>=PI)throw new Error(`hydra-acp: gave up reconnecting after ${e} attempts: ${s.message}`);this.log(`hydra-acp: connect attempt ${e} failed (${s.message}); retrying in ${n}ms`),await AI(n),n=Math.min(n*EI,TI)}}bindStream(e){this.current=e,e.onMessage(n=>{if(MI(n)){let s=this.pendingRequests.get(n.id);s&&(this.pendingRequests.delete(n.id),s.resolve(n))}for(let s of this.messageHandlers)s(n)}),e.onClose(n=>{if(!this.destroyed){if(this.current=void 0,this.pendingRequests.size>0){let s=n??new Error("ws closed before response");for(let{reject:r}of this.pendingRequests.values())r(s);this.pendingRequests.clear()}this.scheduleReconnect(n)}})}async flushQueue(){if(!this.current)return;let e=this.outboundQueue;this.outboundQueue=[];for(let n of e)try{await this.current.send(n)}catch(s){this.outboundQueue.unshift(n),this.scheduleReconnect(s);return}}scheduleReconnect(e){if(!(this.destroyed||this.reconnectInFlight)){if(this.log(`hydra-acp: connection lost (${e?.message??"no error"}); reconnecting...`),this.opts.onDisconnect)try{this.opts.onDisconnect(e)}catch(n){this.log(`hydra-acp: onDisconnect handler threw: ${n.message}`)}this.reconnectInFlight=(async()=>{try{await this.connectWithRetry()}catch(n){for(let s of this.closeHandlers)s(n);this.destroyed=!0}finally{this.reconnectInFlight=void 0}})()}}log(e){if(this.opts.log){this.opts.log(e);return}process.stderr.write(`${e}
|
|
159
|
+
`)}}});function bm(t,e){let n=t&&typeof t=="object"?t.options:void 0;if(Array.isArray(n)){for(let r of e){let i=n.find(o=>typeof o=="object"&&o!==null&&o.kind===r&&typeof o.optionId=="string");if(i?.optionId!==void 0)return i.optionId}let s=n.find(r=>typeof r=="object"&&r!==null&&typeof r.optionId=="string");if(s?.optionId!==void 0)return s.optionId}return e[0]??"allow"}function gs(t){return{outcome:{outcome:"selected",optionId:bm(t,["allow_once","allow_always"])}}}function vm(t){return{outcome:{outcome:"selected",optionId:bm(t,["reject_once","reject_always"])}}}function ta(t){return t&&typeof t=="object"?t:void 0}function ci(t){return typeof t=="string"&&t.length>0?t:void 0}function Im(t){let e=ta(t),n=ta(e?.toolCall),s={paths:[]};if(!n)return s;let r=ci(n.kind);r&&(s.kind=r);let i=new Set,o=c=>{let l=ci(c);l&&!i.has(l)&&(i.add(l),s.paths.push(l))},a=n.locations;if(Array.isArray(a))for(let c of a)o(ta(c)?.path);let d=ta(n.rawInput);if(d){o(d.file_path),o(d.filePath),o(d.path);let c=ci(d.command);c&&(s.command=c);let l=ci(d.url);l&&(s.url=l);let f=ci(d.description);f&&(s.description=f)}return s}function Sm(t){let e=[];return t.command?e.push(`$ ${t.command}`):t.url?e.push(t.url):t.paths.length===1?e.push(t.paths[0]):t.paths.length>1?e.push(`${t.paths[0]} (+${t.paths.length-1} more)`):t.description&&e.push(t.description),e.join(" ").replace(/\s+/g," ").trim()}var na=V(()=>{"use strict"});function MS(){return!!(process.env.NO_UPDATE_NOTIFIER==="1"||process.argv.includes("--no-update-notifier"))}function Mm(t){let n=(t.split("-",1)[0]??t).split("."),s=Number(n[0]),r=Number(n[1]),i=Number(n[2]);return!Number.isFinite(s)||!Number.isFinite(r)||!Number.isFinite(i)?null:[s,r,i]}function $S(t,e){let n=Mm(t),s=Mm(e);if(!n||!s)return t!==e;for(let r=0;r<3;r++){let i=n[r],o=s[r];if(i>o)return!0;if(i<o)return!1}return!1}async function li(){if(jn!==void 0)return jn;if(MS())return jn=null,jn;try{let t=await import("update-notifier"),n=(t.default??t)({pkg:{name:$m,version:me}}),s=n.update;if(s&&typeof s.latest=="string"&&typeof s.current=="string"&&$S(s.latest,s.current)){try{n.config?.set?.("update",s)}catch{}jn={current:s.current,latest:s.latest,type:typeof s.type=="string"?s.type:"unknown"}}else{if(s&&typeof s.latest=="string"&&typeof s.current=="string")try{n.config?.set?.("update",void 0)}catch{}jn=null}}catch{jn=null}return jn}function ui(t){return`hydra-acp ${t.latest} available (current ${t.current}) \xB7 run: npm update -g ${$m}`}var $m,jn,nc=V(()=>{"use strict";Lt();$m="@hydra-acp/cli"});import*as fi from"fs/promises";import*as sc from"path";async function pi(t){let e=t.trim();if(e.length===0)return{ok:!1,reason:"path is empty"};let n=sc.resolve(Ft(e)),s;try{s=await fi.stat(n)}catch{return{ok:!1,reason:`${n} does not exist`}}return s.isDirectory()?{ok:!0,path:n}:{ok:!1,reason:`${n} is not a directory`}}async function _m(t){let e=[],n=new Set,s=r=>{n.has(r)||(n.add(r),e.push(r))};s(t),t.startsWith("/Users/")?s("/home/"+t.slice(7)):t.startsWith("/home/")&&s("/Users/"+t.slice(6));for(let r of e)try{if((await fi.stat(r)).isDirectory())return r}catch{}return null}async function Fm(t){let e=t.lastIndexOf("/"),n,s,r;e===-1?(n="",s=t,r="."):(n=t.slice(0,e+1),s=t.slice(e+1),r=e===0?"/":n);let i=sc.resolve(Ft(r)),o;try{o=(await fi.readdir(i,{withFileTypes:!0})).map(l=>({name:l.name,isDir:l.isDirectory()}))}catch{return{prefix:n,basePrefix:s,matches:[]}}let a=s.startsWith("."),d=o.filter(c=>c.name.startsWith(s)).filter(c=>a||!c.name.startsWith(".")).map(c=>c.isDir?`${c.name}/`:c.name).sort();return{prefix:n,basePrefix:s,matches:d}}var rc=V(()=>{"use strict";Ne()});function FS(t,e){return`[pasted #${t} +${e} lines]`}var _S,oa,ic,un,oc=V(()=>{"use strict";_S=/\[pasted #(\d+) \+\d+ lines\]/g,oa=/\[pasted #(\d+) \+\d+ lines\]$/,ic=/^\[pasted #(\d+) \+\d+ lines\]/;un=class{buffer=[""];row=0;col=0;planMode=!1;historyIndex=-1;queueIndex=-1;savedDraft=null;history=[];historySearch=null;queue=[];turnRunning=!1;killBuffer="";attachments=[];savedAttachments=null;pastes=new Map;nextPasteId=1;collapsePastes;constructor(e={}){this.history=[...e.history??[]],this.planMode=e.planMode??!1,this.collapsePastes=e.collapsePastes??!0}expandedText(){return this.expandPastes(this.bufferText())}state(){return{buffer:[...this.buffer],row:this.row,col:this.col,planMode:this.planMode,historyIndex:this.historyIndex,queueIndex:this.queueIndex,attachments:[...this.attachments],historySearchQuery:this.historySearch?.query??null}}addAttachment(e){this.attachments.push(e)}removeAttachment(e){e<0||e>=this.attachments.length||this.attachments.splice(e,1)}setTurnRunning(e){this.turnRunning=e}setHistory(e){this.history=[...e],this.historyIndex=-1,this.savedDraft=null,this.historySearch=null}setQueue(e){this.queue=[...e],this.queueIndex>=this.queue.length&&(this.queueIndex=-1)}replaceFirstLine(e){this.buffer[0]=e,this.row===0&&(this.col=e.length)}replaceRangeOnCurrentLine(e,n,s){let r=this.currentLine(),i=Math.max(0,Math.min(e,r.length)),o=Math.max(i,Math.min(n,r.length));this.setCurrentLine(r.slice(0,i)+s+r.slice(o)),this.col=i+s.length}setBuffer(e,n=[]){this.loadEntry(e),this.historyIndex=-1,this.queueIndex=-1,this.savedDraft=null,this.savedAttachments=null,this.historySearch=null,this.attachments=[...n]}feed(e){if(this.historySearch!==null){if(e.type==="char")return this.mutateHistorySearchQuery(this.historySearch.query+e.ch.toLowerCase());if(e.type==="paste")return this.mutateHistorySearchQuery(this.historySearch.query+e.text.replace(/\n/g," ").toLowerCase());if(e.type==="key"){if(e.name==="ctrl-r")return this.advanceHistorySearch();if(e.name==="ctrl-s")return this.retreatHistorySearch(),[];if(e.name==="escape"||e.name==="ctrl-c")return this.cancelHistorySearch(),[];if(e.name==="backspace")return this.historySearch.query.length===0?(this.cancelHistorySearch(),[]):this.mutateHistorySearchQuery(this.historySearch.query.slice(0,-1));this.historySearch=null}}if(e.type==="char")return this.insertChar(e.ch),[];if(e.type==="paste"){let n=e.text.split(`
|
|
160
|
+
`).length;if(this.collapsePastes&&n>10){let s=this.nextPasteId++;this.pastes.set(s,e.text),this.insertText(FS(s,n))}else this.insertText(e.text);return[]}return e.type==="attachment-paths"?[]:this.handleKey(e.name)}handleKey(e){switch(e){case"enter":return this.send();case"shift-enter":case"ctrl-enter":return this.amend();case"alt-enter":return this.insertNewline(),[];case"shift-tab":return this.planMode=!this.planMode,[{type:"plan-toggle",on:this.planMode},{type:"redraw-banner"}];case"tab":return this.insertText(" "),[];case"up":return this.handleUp();case"down":return this.handleDown();case"left":return this.moveLeft(),[];case"right":return this.moveRight(),[];case"ctrl-a":return this.col=0,[];case"ctrl-e":return this.col=this.currentLine().length,[];case"home":return this.handleHome();case"end":return this.handleEnd();case"ctrl-b":return this.moveLeft(),[];case"ctrl-f":return this.moveRight(),[];case"ctrl-g":return[{type:"show-help"}];case"alt-b":return this.moveWordBackward(),[];case"alt-f":return this.moveWordForward(),[];case"ctrl-k":return this.killToEnd(),[];case"ctrl-n":return this.handleDown();case"ctrl-o":return[{type:"toggle-options"}];case"backspace":return this.backspace(),[];case"delete":return this.deleteForward(),[];case"ctrl-c":return this.handleCtrlC();case"ctrl-d":return this.bufferIsEmpty()?[{type:"exit"}]:(this.deleteForward(),[]);case"ctrl-l":return[{type:"redraw"}];case"ctrl-p":return[{type:"switch-session"}];case"ctrl-t":return[{type:"toggle-thoughts"}];case"alt-n":case"alt-tab":return[{type:"next-live-session"}];case"ctrl-r":return this.startHistorySearch();case"ctrl-s":return this.amend();case"ctrl-u":return this.killLine(),[];case"ctrl-v":return[{type:"attachment-request",source:"clipboard"}];case"ctrl-w":return this.killWord(),[];case"ctrl-x":return[{type:"toggle-mouse"}];case"ctrl-y":return this.yank(),[];case"escape":return this.turnRunning?[{type:"cancel",prefill:!0}]:[]}}currentLine(){return this.buffer[this.row]??""}setCurrentLine(e){this.buffer[this.row]=e}bufferText(){return this.buffer.join(`
|
|
161
|
+
`)}expandPastes(e){return e.replace(_S,(n,s)=>{let r=parseInt(s,10),i=this.pastes.get(r);return i!==void 0?i:n})}bufferIsEmpty(){return this.buffer.length===1&&this.buffer[0]===""}clearBuffer(){this.buffer=[""],this.row=0,this.col=0,this.historyIndex=-1,this.queueIndex=-1,this.savedDraft=null,this.savedAttachments=null,this.historySearch=null,this.attachments=[]}insertChar(e){if(e.length===0)return;if(e.includes(`
|
|
142
162
|
`)){this.insertText(e);return}let n=this.currentLine();this.setCurrentLine(n.slice(0,this.col)+e+n.slice(this.col)),this.col+=e.length}insertText(e){let n=e.split(`
|
|
143
163
|
`);if(n.length===1){this.insertChar(n[0]??"");return}let s=this.currentLine(),r=s.slice(0,this.col),i=s.slice(this.col),o=n[0]??"",a=n[n.length-1]??"",d=n.slice(1,-1);this.setCurrentLine(r+o);let c=[...d,a+i];this.buffer.splice(this.row+1,0,...c),this.row+=n.length-1,this.col=a.length}insertNewline(){let e=this.currentLine(),n=e.slice(0,this.col),s=e.slice(this.col);this.setCurrentLine(n),this.buffer.splice(this.row+1,0,s),this.row+=1,this.col=0}backspace(){if(this.col>0){let s=this.currentLine(),i=s.slice(0,this.col).match(oa);if(i!==null){this.pastes.delete(parseInt(i[1],10)),this.setCurrentLine(s.slice(0,this.col-i[0].length)+s.slice(this.col)),this.col-=i[0].length;return}this.setCurrentLine(s.slice(0,this.col-1)+s.slice(this.col)),this.col-=1;return}if(this.row===0)return;let e=this.buffer[this.row-1]??"",n=this.currentLine();this.buffer.splice(this.row,1),this.row-=1,this.col=e.length,this.buffer[this.row]=e+n}deleteForward(){let e=this.currentLine();if(this.col<e.length){let s=e.slice(this.col).match(ic);if(s!==null){this.pastes.delete(parseInt(s[1],10)),this.setCurrentLine(e.slice(0,this.col)+e.slice(this.col+s[0].length));return}this.setCurrentLine(e.slice(0,this.col)+e.slice(this.col+1));return}if(this.row<this.buffer.length-1){let n=this.buffer[this.row+1]??"";this.buffer.splice(this.row+1,1),this.setCurrentLine(e+n)}}killLine(){if(this.col>0){let n=this.currentLine();this.killBuffer=n.slice(0,this.col),this.setCurrentLine(n.slice(this.col)),this.col=0;return}if(this.row===0)return;if(this.currentLine().length===0){this.killBuffer=`
|
|
144
164
|
`,this.buffer.splice(this.row,1),this.row-=1,this.col=this.currentLine().length;return}let e=this.buffer[this.row-1]??"";this.killBuffer=e+`
|
|
145
165
|
`,this.buffer.splice(this.row-1,1),this.row-=1}killToEnd(){let e=this.currentLine();if(this.col<e.length){this.killBuffer=e.slice(this.col),this.setCurrentLine(e.slice(0,this.col));return}if(this.row>=this.buffer.length-1)return;if(e.length===0){this.killBuffer=`
|
|
146
166
|
`,this.buffer.splice(this.row,1);return}let n=this.buffer[this.row+1]??"";this.killBuffer=`
|
|
147
167
|
`+n,this.buffer.splice(this.row+1,1)}killWord(){let e=this.currentLine();if(this.col===0){this.backspace();return}let s=e.slice(0,this.col).match(oa);if(s!==null){this.killBuffer=s[0];let o=this.col-s[0].length;this.setCurrentLine(e.slice(0,o)+e.slice(this.col)),this.col=o;return}let r=this.col;for(;r>0&&/\s/.test(e[r-1]??"");)r-=1;for(;r>0&&!/\s/.test(e[r-1]??"");)r-=1;let i=e.slice(r,this.col);i.length>0&&(this.killBuffer=i),this.setCurrentLine(e.slice(0,r)+e.slice(this.col)),this.col=r}yank(){this.killBuffer.length!==0&&this.insertText(this.killBuffer)}moveLeft(){if(this.col>0){let n=this.currentLine().slice(0,this.col).match(oa);if(n!==null){this.col-=n[0].length;return}this.col-=1;return}this.row>0&&(this.row-=1,this.col=this.currentLine().length)}moveRight(){let e=this.currentLine();if(this.col<e.length){let s=e.slice(this.col).match(ic);if(s!==null){this.col+=s[0].length;return}this.col+=1;return}this.row<this.buffer.length-1&&(this.row+=1,this.col=0)}moveWordBackward(){if(this.col===0){if(this.row===0)return;this.row-=1,this.col=this.currentLine().length;return}let e=this.currentLine(),n=this.col;for(;n>0&&/\s/.test(e[n-1]??"");)n-=1;let r=e.slice(0,n).match(oa);if(r!==null){this.col=n-r[0].length;return}for(;n>0&&!/\s/.test(e[n-1]??"");)n-=1;this.col=n}moveWordForward(){let e=this.currentLine();if(this.col>=e.length){if(this.row>=this.buffer.length-1)return;this.row+=1,this.col=0;return}let n=this.col;for(;n<e.length&&/\s/.test(e[n]??"");)n+=1;let r=e.slice(n).match(ic);if(r!==null){this.col=n+r[0].length;return}for(;n<e.length&&!/\s/.test(e[n]??"");)n+=1;this.col=n}handleUp(){return this.row>0?(this.row-=1,this.col=Math.min(this.col,this.currentLine().length),[]):this.queueIndex===-1&&this.historyIndex===-1?this.queue.length===0&&this.history.length===0?[]:(this.savedDraft={buffer:[...this.buffer],row:this.row,col:this.col},this.savedAttachments=[...this.attachments],this.attachments=[],this.queue.length>0?(this.queueIndex=this.queue.length-1,this.loadEntry(this.queue[this.queueIndex]??"")):(this.historyIndex=this.history.length-1,this.loadEntry(this.history[this.historyIndex]??"")),[]):this.queueIndex>=0?this.queueIndex>0?(this.queueIndex-=1,this.loadEntry(this.queue[this.queueIndex]??""),[]):this.history.length===0?[]:(this.queueIndex=-1,this.historyIndex=this.history.length-1,this.loadEntry(this.history[this.historyIndex]??""),[]):(this.historyIndex>0&&(this.historyIndex-=1,this.loadEntry(this.history[this.historyIndex]??"")),[])}handleDown(){return this.row<this.buffer.length-1&&this.historyIndex===-1&&this.queueIndex===-1?(this.row+=1,this.col=Math.min(this.col,this.currentLine().length),[]):this.historyIndex>=0?this.historyIndex<this.history.length-1?(this.historyIndex+=1,this.loadEntry(this.history[this.historyIndex]??""),[]):(this.historyIndex=-1,this.queue.length>0?(this.queueIndex=0,this.loadEntry(this.queue[this.queueIndex]??""),[]):(this.restoreDraft(),[])):this.queueIndex>=0?this.queueIndex<this.queue.length-1?(this.queueIndex+=1,this.loadEntry(this.queue[this.queueIndex]??""),[]):(this.queueIndex=-1,this.restoreDraft(),[]):[]}restoreDraft(){this.savedDraft?(this.buffer=[...this.savedDraft.buffer],this.row=this.savedDraft.row,this.col=this.savedDraft.col,this.savedDraft=null,this.attachments=this.savedAttachments??[],this.savedAttachments=null):this.clearBuffer()}startHistorySearch(){let e=this.bufferText().toLowerCase();if(e.length===0)return this.historySearch={query:"",matchIndices:[],cursor:0,savedDraft:{buffer:[...this.buffer],row:this.row,col:this.col}},[];let n=this.findHistoryMatches(e);return n.length===0?[{type:"escalate-search",query:e}]:(this.historySearch={query:e,matchIndices:n,cursor:0,savedDraft:{buffer:[...this.buffer],row:this.row,col:this.col}},this.loadEntry(this.history[n[0]]??""),[])}advanceHistorySearch(){if(this.historySearch===null)return[];let e=this.historySearch;if(e.cursor>=e.matchIndices.length-1){if(e.query.length===0)return[];let r=e.query,i=e.savedDraft;return this.historySearch=null,this.buffer=[...i.buffer],this.row=i.row,this.col=i.col,[{type:"escalate-search",query:r}]}e.cursor+=1;let s=e.matchIndices[e.cursor];return this.loadEntry(this.history[s]??""),[]}retreatHistorySearch(){if(this.historySearch===null||this.historySearch.cursor===0)return;this.historySearch.cursor-=1;let e=this.historySearch.matchIndices[this.historySearch.cursor];this.loadEntry(this.history[e]??"")}mutateHistorySearchQuery(e){if(this.historySearch===null)return[];if(e.length===0){this.historySearch.query="",this.historySearch.matchIndices=[],this.historySearch.cursor=0;let s=this.historySearch.savedDraft;return this.buffer=[...s.buffer],this.row=s.row,this.col=s.col,[]}let n=this.findHistoryMatches(e);if(n.length===0){let s=this.historySearch.savedDraft;return this.historySearch=null,this.buffer=[...s.buffer],this.row=s.row,this.col=s.col,[{type:"escalate-search",query:e}]}return this.historySearch.query=e,this.historySearch.matchIndices=n,this.historySearch.cursor=0,this.loadEntry(this.history[n[0]]??""),[]}findHistoryMatches(e){let n=[];for(let s=this.history.length-1;s>=0;s--){let r=this.history[s]??"";(e.length===0||r.toLowerCase().includes(e))&&n.push(s)}return n}cancelHistorySearch(){if(this.historySearch===null)return;let e=this.historySearch.savedDraft;this.historySearch=null,this.buffer=[...e.buffer],this.row=e.row,this.col=e.col}loadEntry(e){this.buffer=e.split(`
|
|
148
|
-
`),this.buffer.length===0&&(this.buffer=[""]),this.row=this.buffer.length-1,this.col=(this.buffer[this.row]??"").length}send(){let e=this.bufferText(),n=this.expandPastes(e);if(this.queueIndex>=0&&this.queueIndex<this.queue.length){let i=this.queueIndex,o=[...this.attachments];return this.clearBuffer(),n.trim().length===0?[{type:"queue-remove",index:i}]:[{type:"queue-edit",index:i,text:n,displayText:e,attachments:o}]}if(n.trim().length===0&&this.attachments.length===0)return[];let s=this.planMode,r=[...this.attachments];return this.clearBuffer(),[{type:"send",text:n,displayText:e,planMode:s,attachments:r}]}amend(){let e=this.bufferText(),n=this.expandPastes(e);if(this.queueIndex>=0&&this.queueIndex<this.queue.length){let i=this.queueIndex,o=this.planMode,a=[...this.attachments],d=n.trim().length===0&&a.length===0;return this.clearBuffer(),d?[{type:"queue-remove",index:i}]:[{type:"queue-remove",index:i},{type:"amend",text:n,displayText:e,planMode:o,attachments:a}]}if(n.trim().length===0&&this.attachments.length===0)return[];let s=this.planMode,r=[...this.attachments];return this.clearBuffer(),[{type:"amend",text:n,displayText:e,planMode:s,attachments:r}]}handleHome(){return this.row!==0||this.col!==0?(this.row=0,this.col=0,[]):[{type:"scroll-to-top"}]}handleEnd(){let e=this.buffer.length-1,n=(this.buffer[e]??"").length;return this.row!==e||this.col!==n?(this.row=e,this.col=n,[]):[{type:"scroll-to-bottom"}]}handleCtrlC(){if(this.queueIndex>=0){let e=this.queueIndex;return this.queueIndex=-1,this.restoreDraft(),[{type:"queue-remove",index:e}]}return!this.bufferIsEmpty()||this.attachments.length>0?(this.buffer=[""],this.row=0,this.col=0,this.attachments=[],this.historyIndex=-1,this.savedDraft=null,this.savedAttachments=null,[]):this.turnRunning?[{type:"cancel"}]:[{type:"exit"}]}}});import
|
|
168
|
+
`),this.buffer.length===0&&(this.buffer=[""]),this.row=this.buffer.length-1,this.col=(this.buffer[this.row]??"").length}send(){let e=this.bufferText(),n=this.expandPastes(e);if(this.queueIndex>=0&&this.queueIndex<this.queue.length){let i=this.queueIndex,o=[...this.attachments];return this.clearBuffer(),n.trim().length===0?[{type:"queue-remove",index:i}]:[{type:"queue-edit",index:i,text:n,displayText:e,attachments:o}]}if(n.trim().length===0&&this.attachments.length===0)return[];let s=this.planMode,r=[...this.attachments];return this.clearBuffer(),[{type:"send",text:n,displayText:e,planMode:s,attachments:r}]}amend(){let e=this.bufferText(),n=this.expandPastes(e);if(this.queueIndex>=0&&this.queueIndex<this.queue.length){let i=this.queueIndex,o=this.planMode,a=[...this.attachments],d=n.trim().length===0&&a.length===0;return this.clearBuffer(),d?[{type:"queue-remove",index:i}]:[{type:"queue-remove",index:i},{type:"amend",text:n,displayText:e,planMode:o,attachments:a}]}if(n.trim().length===0&&this.attachments.length===0)return[];let s=this.planMode,r=[...this.attachments];return this.clearBuffer(),[{type:"amend",text:n,displayText:e,planMode:s,attachments:r}]}handleHome(){return this.row!==0||this.col!==0?(this.row=0,this.col=0,[]):[{type:"scroll-to-top"}]}handleEnd(){let e=this.buffer.length-1,n=(this.buffer[e]??"").length;return this.row!==e||this.col!==n?(this.row=e,this.col=n,[]):[{type:"scroll-to-bottom"}]}handleCtrlC(){if(this.queueIndex>=0){let e=this.queueIndex;return this.queueIndex=-1,this.restoreDraft(),[{type:"queue-remove",index:e}]}return!this.bufferIsEmpty()||this.attachments.length>0?(this.buffer=[""],this.row=0,this.col=0,this.attachments=[],this.historyIndex=-1,this.savedDraft=null,this.savedAttachments=null,[]):this.turnRunning?[{type:"cancel"}]:[{type:"exit"}]}}});import OS from"path";function mi(t){return Om[OS.extname(t).toLowerCase()]??null}function LS(t){return mi(t)!==null}function ac(t){let e=t.match(/^data:(image\/[a-z0-9.+\-]+);base64,([A-Za-z0-9+/=]+)$/);if(!e)return null;let n=e[1].toLowerCase();if(!BS.has(n))return null;let s=e[2],r=s.endsWith("==")?2:s.endsWith("=")?1:0,i=Math.floor(s.length*3/4)-r;return{mimeType:n,data:s,sizeBytes:i}}function NS(t){return ac(t)!==null}function Et(t){return t>=1024*1024?`${(t/(1024*1024)).toFixed(1)}MB`:t>=1024?`${(t/1024).toFixed(0)}KB`:`${t}B`}function Lm(t){let e=t.trim();if(e.length===0)return null;let n=[],s=0;for(;s<e.length;){for(;s<e.length&&/\s/.test(e[s]??"");)s++;if(s>=e.length)break;let r=e[s],i="";if(r==="'"||r==='"'){let a=r;for(s++;s<e.length&&e[s]!==a;)i+=e[s],s++;if(s>=e.length)return null;s++}else for(;s<e.length&&!/\s/.test(e[s]??"");)e[s]==="\\"&&s+1<e.length?(i+=e[s+1],s+=2):(i+=e[s],s++);if(i.startsWith("data:")){if(!NS(i))return null;n.push(i);continue}let o=i;if(o.startsWith("file://")&&(o=decodeURI(o.slice(7))),!o.startsWith("/")||!LS(o))return null;n.push(o)}return n.length>0?n:null}var Xt,Om,BS,aa=V(()=>{"use strict";Xt=10*1024*1024,Om={".png":"image/png",".jpg":"image/jpeg",".jpeg":"image/jpeg",".gif":"image/gif",".webp":"image/webp"};BS=new Set(Object.values(Om))});import DS from"string-width";function Bm(t,e){if(!t||e<=0)return 0;let n=0;for(let s of HS.segment(t)){let r=DS(s.segment);if(e<n+r)return s.index;if(n+=r,e===n)return s.index+s.segment.length}return t.length}function Nm(t,e){if(e<=0)return 0;let n=0,s=0;for(let r of t)if(r.width>0&&e<n+r.width||(n+=r.width,s+=r.text.length,r.width>0&&e===n))return s;return s}var HS,Dm=V(()=>{"use strict";HS=new Intl.Segmenter(void 0,{granularity:"grapheme"})});import{spawn as US}from"child_process";import dc from"fs/promises";import jS from"os";import qS from"path";async function jm(t={}){let e={...cc,...t};return e.platform==="darwin"?KS(e):e.platform==="linux"?VS(e):{ok:!1,reason:`clipboard paste is not supported on ${e.platform}`}}async function qm(t={}){let e={...cc,...t},n,s;if(e.platform==="darwin")n="pbpaste",s=[];else if(e.platform==="linux")if(e.env.WAYLAND_DISPLAY&&await vr(e,"wl-paste"))n="wl-paste",s=["--primary","-n"];else if(e.env.DISPLAY&&await vr(e,"xclip"))n="xclip",s=["-selection","primary","-o"];else return{ok:!1,reason:"install wl-clipboard (Wayland) or xclip (X11) to paste the selection"};else return{ok:!1,reason:`selection paste is not supported on ${e.platform}`};try{let r=await hi(e.spawn,n,s);return r.length===0?{ok:!1,reason:"selection is empty"}:{ok:!0,kind:"text",text:lc(r.toString("utf-8"))}}catch{return{ok:!1,reason:"selection read failed"}}}async function Wm(t,e={}){let{target:n="both",...s}=e,r={...cc,...s},i=await WS(r,t,n);if(i.ok)return i;let o=zS(r,t,n);return o.ok||o.reason!==zm?o:i}async function WS(t,e,n){let s=Buffer.from(e,"utf-8");if(t.platform==="darwin")try{return await da(t.spawn,"pbcopy",[],s),{ok:!0,method:"pbcopy"}}catch{return{ok:!1,reason:"pbcopy failed"}}if(t.platform==="linux"){let r=n==="clipboard"||n==="both",i=n==="primary"||n==="both";return t.env.WAYLAND_DISPLAY&&await vr(t,"wl-copy")?Um(t,s,"wl-copy",[],["--primary"],r,i):t.env.DISPLAY&&await vr(t,"xclip")?Um(t,s,"xclip",["-selection","clipboard","-i"],["-selection","primary","-i"],r,i):{ok:!1,reason:"install wl-clipboard (Wayland) or xclip (X11) to copy to the clipboard"}}return{ok:!1,reason:`clipboard copy is not supported on ${t.platform}`}}async function Um(t,e,n,s,r,i,o){let a=n;if(i){try{await da(t.spawn,n,s,e)}catch{return{ok:!1,reason:`${n} failed`}}if(o)try{await da(t.spawn,n,r,e)}catch{}return{ok:!0,method:a}}try{return await da(t.spawn,n,r,e),{ok:!0,method:a}}catch{return{ok:!1,reason:`${n} failed`}}}function zS(t,e,n){let s=Buffer.from(e,"utf-8").toString("base64");if(s.length>Hm)return{ok:!1,reason:`selection is too large for terminal clipboard escape (${s.length} > ${Hm} bytes)`};let i=`\x1B]52;${n==="both"?"cp":n==="primary"?"p":"c"};${s}\x07`;return t.env.TMUX&&(i=`\x1BPtmux;${i.replace(/\x1b/g,"\x1B\x1B")}\x1B\\`),(t.ttyWrite??JS)(i)?{ok:!0,method:"osc52"}:{ok:!1,reason:zm}}function JS(t){let e=[process.stderr,process.stdout];for(let n of e)if(n&&n.isTTY)try{return n.write(t),!0}catch{}return!1}async function KS(t){let e=qS.join(t.tmpdir(),`hydra-clipboard-${Date.now()}-${process.pid}.png`),n=["set png_data to the clipboard as \xABclass PNGf\xBB",`set out_file to (open for access (POSIX file "${e}") with write permission)`,"write png_data to out_file","close access out_file"],s=[];for(let r of n)s.push("-e",r);try{await Jm(t.spawn,"osascript",s);let r=await ZS(e,!0);if(r.ok||r.reason.startsWith("clipboard image is"))return r}catch{await dc.unlink(e).catch(()=>{})}try{let r=await hi(t.spawn,"pbpaste",[]);return r.length===0?{ok:!1,reason:"clipboard is empty"}:{ok:!0,kind:"text",text:lc(r.toString("utf-8"))}}catch{return{ok:!1,reason:"clipboard read failed"}}}async function VS(t){let e=await YS(t);if(!e)return{ok:!1,reason:"install wl-clipboard (Wayland) or xclip (X11) to paste from the clipboard"};let n=await XS(t,e),s=GS(n);if(s)try{let r=await hi(t.spawn,e.cmd,e.imageArgs(s));if(r.length>0)return r.length>Xt?{ok:!1,reason:`clipboard image is ${Et(r.length)}, max ${Et(Xt)}`}:{ok:!0,kind:"image",attachment:{mimeType:s,data:r.toString("base64"),sizeBytes:r.length}}}catch{}try{let r=await hi(t.spawn,e.cmd,e.textArgs);return r.length===0?{ok:!1,reason:"clipboard is empty"}:{ok:!0,kind:"text",text:lc(r.toString("utf-8"))}}catch{return{ok:!1,reason:"clipboard read failed"}}}async function YS(t){return t.env.WAYLAND_DISPLAY&&await vr(t,"wl-paste")?{cmd:"wl-paste",listTargetsArgs:["--list-types"],imageArgs:e=>["-t",e],textArgs:["-n"]}:t.env.DISPLAY&&await vr(t,"xclip")?{cmd:"xclip",listTargetsArgs:["-selection","clipboard","-t","TARGETS","-o"],imageArgs:e=>["-selection","clipboard","-t",e,"-o"],textArgs:["-selection","clipboard","-o"]}:null}function GS(t){let e=new Set(t.map(n=>n.toLowerCase()));for(let n of QS)if(e.has(n))return n;return null}async function XS(t,e){try{return(await hi(t.spawn,e.cmd,e.listTargetsArgs)).toString("utf-8").split(`
|
|
149
169
|
`).map(s=>s.trim()).filter(s=>s.length>0)}catch{return[]}}function lc(t){return t.replace(/\r\n?/g,`
|
|
150
|
-
`)}async function vr(t,e){try{return await
|
|
151
|
-
`)}function
|
|
152
|
-
`);return e===-1?t:`${t.slice(0,e)} \u21B5`}function
|
|
170
|
+
`)}async function vr(t,e){try{return await Jm(t.spawn,"which",[e]),!0}catch{return!1}}async function ZS(t,e){try{let n=await dc.readFile(t);return e&&await dc.unlink(t).catch(()=>{}),n.length===0?{ok:!1,reason:"no image on clipboard"}:n.length>Xt?{ok:!1,reason:`clipboard image is ${Et(n.length)}, max ${Et(Xt)}`}:{ok:!0,kind:"image",attachment:{mimeType:mi(t)??"image/png",data:n.toString("base64"),sizeBytes:n.length}}}catch{return{ok:!1,reason:"failed to read clipboard image"}}}function Jm(t,e,n){return new Promise((s,r)=>{let i=t(e,n);i.stdout?.on("data",()=>{}),i.stderr?.on("data",()=>{}),i.on("error",r),i.on("close",o=>{o===0?s():r(new Error(`${e} exited ${o}`))})})}function da(t,e,n,s){return new Promise((r,i)=>{let o=t(e,n,{stdio:["pipe","ignore","ignore"]});o.stdout?.on("data",()=>{}),o.stderr?.on("data",()=>{}),o.on("error",i),o.on("close",d=>{d===0?r():i(new Error(`${e} exited ${d}`))});let a=o.stdin;if(!a){i(new Error(`${e} has no stdin`));return}a.on("error",i),a.end(s)})}function hi(t,e,n){return new Promise((s,r)=>{let i=t(e,n),o=[],a=i.stdout===null,d=null,c=!1,l=()=>{c||!a||d===null||(c=!0,d===0?s(Buffer.concat(o)):r(new Error(`${e} exited ${d}`)))};i.stdout?.on("data",f=>{o.push(typeof f=="string"?Buffer.from(f):f)}),i.stdout?.on("end",()=>{a=!0,l()}),i.stderr?.on("data",()=>{}),i.on("error",f=>{c||(c=!0,r(f))}),i.on("close",f=>{d=f??0,l()})})}var cc,Hm,zm,QS,uc=V(()=>{"use strict";aa();cc={platform:process.platform,env:process.env,spawn:US,tmpdir:jS.tmpdir};Hm=74994;zm="no TTY available for OSC 52 clipboard write";QS=["image/png","image/jpeg","image/gif","image/webp"]});function ek(){gi===0&&process.stdout.write("\x1B[?2026h"),gi++}function tk(){gi!==0&&(gi--,gi===0&&process.stdout.write("\x1B[?2026l"))}function Pe(t){ek();try{t()}finally{tk()}}var gi,fc=V(()=>{"use strict";gi=0});import fa from"string-width";import nk from"wrap-ansi";function uk(t){let e=t.replace(/\r\n?$|\n$/,"");return lk.test(e)?e:null}function fk(t){return t.includes("LEFT")?"left":t.includes("RIGHT")?"right":t.includes("MIDDLE")?"middle":t==="MOUSE_DRAG"||t==="MOUSE_BUTTON_RELEASED"?"left":"other"}function pk(t,e,n,s=null,r=null,i=null){let o=r===null?"":`a${r}`,a=i===null?"":`s${i.start}:${i.end}${i.toEndOfLine?"f":""}`;if(!n)return`${t}|${e}|empty|${s??""}|${o}|${a}`;let d=n.iterm2Image?`i${n.iterm2Image.heightCells}:${n.iterm2Image.data.length}`:"";return`${t}|${e}|${n.prefix??""}|${n.prefixStyle??""}|${n.body}|${n.bodyStyle??""}|${n.ansi?"1":"0"}|${n.fillRow?"1":"0"}|${s??""}|${o}|${a}|${d}`}function pn(t,e){let n=[];for(let s=0;s<t.length;s++){let r=t[s]??"";if(r.length===0){n.push({bufferIdx:s,startCol:0,endCol:0});continue}let i=0;for(;i<r.length;){if(r.length-i<=e){n.push({bufferIdx:s,startCol:i,endCol:r.length}),i=r.length;break}let o=-1;for(let a=i+e-1;a>=i;a--){let d=r[a];if(d===" "||d===" "){o=a+1;break}}o===-1&&(o=i+e),n.push({bufferIdx:s,startCol:i,endCol:o}),i=o}}return n.length===0&&n.push({bufferIdx:0,startCol:0,endCol:0}),n}function Wn(t,e,n){let s=0,r=0,i=-1;for(let d=0;d<t.length;d++){let c=t[d];if(!(!c||c.bufferIdx!==e.row)&&(i=d,e.col>=c.startCol&&e.col<c.endCol)){s=d,r=e.col-c.startCol,i=-1;break}}if(i!==-1){let d=t[i];d&&(s=i,r=e.col-d.startCol)}let o=Math.min(n,Math.max(1,t.length)),a=0;return t.length>o&&(a=Math.max(0,Math.min(t.length-o,s-(o-1))),s<a&&(a=s),s>=a+o&&(a=s-o+1)),{cursorVisualRow:s,cursorVisualCol:r,windowStart:a,rendered:o}}function Vm(t,e,n,s,r=null,i=0){if(e.length===0)return;if(s.length===0){fn(t,e,n);return}let o=e.toLowerCase(),a=0;for(;a<e.length;){let d=o.indexOf(s,a);if(d===-1){fn(t,e.slice(a),n);return}d>a&&fn(t,e.slice(a,d),n);let c=r!==null&&d===r;fn(t,e.slice(d,d+s.length),c?"search-highlight-active":"search-highlight"),a=d+s.length}}function ca(t){return t==="agent"||t==="thought"||t==="heading-1"||t==="heading-2"||t==="heading-3"}function fn(t,e,n){if(e.length!==0)switch(n){case"user":t.bgColorGrayscale.bold.noFormat(43,e);return;case"agent":t(e);return;case"thought":t.brightBlack(e);return;case"tool":t.brightBlue.noFormat(e);return;case"tool-status-ok":t.green.noFormat(e);return;case"tool-status-fail":t.bold.red.noFormat(e);return;case"tool-status-pending":t.dim.noFormat(e);return;case"tool-status-running":t.brightYellow.noFormat(e);return;case"tool-status-cancelled":t.dim.noFormat(e);return;case"plan":t.brightYellow.noFormat(e);return;case"plan-done":t.green.noFormat(e);return;case"plan-pending":t.dim.noFormat(e);return;case"system":t.brightYellow.noFormat(e);return;case"info":t.cyan.noFormat(e);return;case"dim":t.dim.noFormat(e);return;case"code":t.bgColorGrayscale.white.noFormat(28,e);return;case"heading-1":t.bold.brightYellow(e);return;case"heading-2":t.bold.brightCyan(e);return;case"heading-3":t.bold(e);return;case"search-highlight":t.bgBrightYellow.black.noFormat(e);return;case"selection-highlight":t.inverse.noFormat(e);return;case"search-highlight-active":t.bgRed.brightWhite.noFormat(e);return;default:t.noFormat(e)}}function mk(t,e){return e<=0?[t]:t.length===0?[""]:nk(t,e,{hard:!0,trim:!1}).split(`
|
|
171
|
+
`)}function th(t){eh=t}function qn(t){return fa(t,{ambiguousIsNarrow:!eh})}function ma(t,e){if(t.charCodeAt(e)!==94)return null;let n=t[e+1];if(n===void 0)return null;if(n==="^")return{text:"^^",width:1};if(n==="["){let s=t.indexOf("]",e+2);if(s!==-1)return{text:t.slice(e,s+1),width:0}}return hk.test(n)?{text:t.slice(e,e+2),width:0}:null}function gk(t){if(!t.includes("^"))return t;let e="",n=0;for(;n<t.length;){let s=ma(t,n);if(s){s.width>0&&(e+="^"),n+=s.text.length;continue}e+=t[n],n+=1}return e}function nh(t){if(!t.includes("^"))return!1;for(let e=0;e<t.length;e++)if(ma(t,e))return!0;return!1}function*vc(t){let e=0;for(;e<t.length;){let n=ma(t,e);if(n){yield{text:n.text,width:n.width},e+=n.text.length;continue}let s=t.length,r=t.indexOf("^",e);for(;r!==-1&&r<t.length;){if(ma(t,r)){s=r;break}r=t.indexOf("^",r+1)}if(s===e){yield{text:"^",width:1},e+=1;continue}for(let{segment:i}of bc.segment(t.slice(e,s)))yield{text:i,width:qn(i)};e=s}}function yk(t,e,n){let s=`\x1B]1337;File=inline=1;height=${e};preserveAspectRatio=1:${t}\x07`;return n?`\x1BPtmux;${s.replace(/\x1b/g,"\x1B\x1B")}\x1B\\`:s}function wk(t,e,n={}){if(e<=0)return[t];if(t.length===0)return[""];let s=n.stripMarkup===!0&&nh(t);return!s&&!Zm.test(t)?bk(t,e):vk(t,e,s)}function bk(t,e){let n=[],s=t;for(;s.length>e;){let r=s.slice(0,e+1),i=-1;for(let o=Math.min(e,r.length-1);o>=0;o--)if(r[o]===" "){i=o;break}i<=0?(n.push(s.slice(0,e)),s=s.slice(e)):(n.push(s.slice(0,i)),s=s.slice(i+1))}return n.push(s),n}function vk(t,e,n){let s=[],r=n?[...vc(t)]:Ik(t),i=0;for(;i<r.length;){let o="",a=0,d=-1,c="";for(;i<r.length;){let l=r[i];if(a+l.width>e){l.text===" "&&l.width===1&&(d=i,c=o);break}l.text===" "&&l.width===1&&(d=i,c=o),o+=l.text,a+=l.width,i+=1}if(i>=r.length){s.push(o);break}d>=0?(s.push(c),i=d+1):o.length===0?(s.push(r[i].text),i+=1):s.push(o)}return s}function Ik(t){let e=[];for(let{segment:n}of bc.segment(t))e.push({text:n,width:qn(n)});return e}function ot(t,e,n={}){if(e<=0)return"";let s=n.stripMarkup===!0&&nh(t);if(!s&&t.length<=e&&!Zm.test(t))return t;if(!s)return qn(t)<=e?t:e<=1?Ym(t,e):Ym(t,e-1)+"\u2026";let r=[...vc(t)],i=0;for(let o of r)i+=o.width;return i<=e?t:e<=1?Qm(r,e):Qm(r,e-1)+"\u2026"}function Ym(t,e){if(e<=0)return"";let n="",s=0;for(let{segment:r}of bc.segment(t)){let i=qn(r);if(s+i>e)break;n+=r,s+=i}return n}function Qm(t,e){if(e<=0)return"";let n="",s=0;for(let r of t){if(s+r.width>e)break;n+=r.text,s+=r.width}return n}function Sk(t){let e=t.indexOf(`
|
|
172
|
+
`);return e===-1?t:`${t.slice(0,e)} \u21B5`}function kk(t){if(!t)return null;let e=[];return typeof t.used=="number"?typeof t.size=="number"&&t.size>0?e.push(`${la(t.used)}/${la(t.size)}`):e.push(la(t.used)):typeof t.size=="number"&&e.push(`/${la(t.size)}`),typeof t.costAmount=="number"&&e.push(_d(t.costAmount,t.costCurrency)),e.length===0?null:e.join(" \xB7 ")}function la(t){return t>=1e6?`${(t/1e6).toFixed(1)}M`:t>=1e3?`${(t/1e3).toFixed(1)}k`:`${t}`}function ha(t){switch(t){case"ENTER":case"KP_ENTER":return"enter";case"ALT_ENTER":case"META_ENTER":return"alt-enter";case"SHIFT_ENTER":return"shift-enter";case"CTRL_ENTER":return"ctrl-enter";case"CTRL_J":return"ctrl-enter";case"ALT_B":case"META_B":return"alt-b";case"ALT_F":case"META_F":return"alt-f";case"ALT_N":case"META_N":return"alt-n";case"ALT_TAB":case"META_TAB":return"alt-tab";case"CTRL_T":return"ctrl-t";case"SHIFT_TAB":return"shift-tab";case"TAB":return"tab";case"UP":return"up";case"DOWN":return"down";case"LEFT":return"left";case"RIGHT":return"right";case"HOME":return"home";case"END":return"end";case"BACKSPACE":return"backspace";case"DELETE":return"delete";case"CTRL_A":return"ctrl-a";case"CTRL_B":return"ctrl-b";case"CTRL_C":return"ctrl-c";case"CTRL_D":return"ctrl-d";case"CTRL_E":return"ctrl-e";case"CTRL_F":return"ctrl-f";case"CTRL_G":return"ctrl-g";case"CTRL_K":return"ctrl-k";case"CTRL_L":return"ctrl-l";case"CTRL_N":return"ctrl-n";case"CTRL_O":return"ctrl-o";case"CTRL_P":return"ctrl-p";case"CTRL_R":return"ctrl-r";case"CTRL_S":return"ctrl-s";case"CTRL_U":return"ctrl-u";case"CTRL_V":return"ctrl-v";case"CTRL_W":return"ctrl-w";case"CTRL_X":return"ctrl-x";case"CTRL_Y":return"ctrl-y";case"ESCAPE":return"escape";default:return null}}function ua(){let t=["\x1B[?1000l","\x1B[?1002l","\x1B[?1003l","\x1B[?1006l","\x1B[?1015l","\x1B[=0;0w","\x1B[?2004l","\x1B[>4;0m","\x1B[>5;0m","\x1B[<u","\x1B[?1l","\x1B>","\x1B[?7h","\x1B[?25h","\x1B]9;4;0\x07","\x1B[?1049l"].join("");try{process.stdout.write(t)}catch{}}function sh(t){let e=[["width",80],["height",24]];for(let[n,s]of e){let r=Object.getOwnPropertyDescriptor(t,n);if(r&&r.get)continue;let i=Symbol(`raw-${n}`),o=t;o[i]=r?r.value:void 0,Object.defineProperty(t,n,{configurable:!0,enumerable:!0,get(){let a=this[i];return typeof a=="number"&&Number.isFinite(a)&&a>0?a:s},set(a){this[i]=a}})}}function Xm(t,e){let n={97:"ctrl-a",98:"ctrl-b",99:"ctrl-c",100:"ctrl-d",101:"ctrl-e",102:"ctrl-f",103:"ctrl-g",104:"backspace",105:"tab",106:"ctrl-enter",107:"ctrl-k",108:"ctrl-l",109:"enter",110:"ctrl-n",111:"ctrl-o",112:"ctrl-p",114:"ctrl-r",115:"ctrl-s",116:"ctrl-t",117:"ctrl-u",118:"ctrl-v",119:"ctrl-w",120:"ctrl-x",121:"ctrl-y"};return e===5?n[t]??null:t===27?"escape":t===9?e===2?"shift-tab":e===3?"alt-tab":e===1?"tab":null:t===13?e===2?"shift-enter":e===3?"alt-enter":e===5?"ctrl-enter":e===1?"enter":null:t===127&&e===1?"backspace":e===3?t===98||t===66?"alt-b":t===102||t===70?"alt-f":t===110||t===78?"alt-n":null:null}var sk,Km,pc,rk,je,Ye,qe,mc,hc,ik,ok,ak,gc,yc,wc,dk,ck,lk,pa,Zm,bc,eh,hk,Gm,Ic=V(()=>{"use strict";Fd();ue();Yt();aa();di();Dm();uc();fc();sk=500,Km=1,pc=/[A-Za-z0-9_]/,rk=/\x1b\[[0-9;]*[A-Za-z]/g,je=1,Ye=1,qe=1,mc=8,hc=5,ik=12,ok=12,ak=30,gc=6,yc=4,wc=2,dk=1e3,ck=1e4,lk=/^(https?|ftp):\/\/\S+$/;pa=class{term;dispatcher;onKey;onBlockClick;onMouse;onBlockVisible;onSuspend;pendingVisibleKeys=new Set;lines=[];keyedBlocks=new Map;stickyBottomKey=null;streamingActive=!1;hideThoughts=!1;lastPromptRows=0;queuedTexts=[];lastQueueEditingIndex=-1;attachments=[];repaintPaused=0;repaintPending=!1;lastRepaintAt=0;throttledRepaintTimer=null;contentRepaintThrottleMs;maxScrollbackLines;nextLineId=1;lineIds=new WeakMap;wrapCache=new Map;wrapCacheWidth=0;wrapOrigin=new WeakMap;lastFrameRows=new Map;lastFrameW=0;lastFrameH=0;permissionPrompt=null;optionsPrompt=null;confirmPrompt=null;helpPrompt=null;completions=[];scrollOffset=0;scrollbackSearch=null;scrollbackHighlight=null;selection=null;selectionRenderBounds=null;bannerNotification=null;bannerNotificationTimer=null;bannerSearchIndicator=null;banner={status:"ready",currentMode:void 0,hint:"\u21E7\u21E5 mode \xB7 \u2303P pick \xB7 \u2303G guide \xB7 \u2303D detach",queued:0};sessionbar={agent:"?",cwd:"?",sessionId:"?"};lastWindowTitle=null;resizeHandler;keyHandler;mouseHandler;pressCell=null;selectionAnchor=null;selectionDragStarted=!1;doubleClickPending=!1;lastLeftClick=null;started=!1;terminalKitStdinHandler=null;pasteActive=!1;pasteBuffer="";rawStdinHandler;mouseEnabled;inAppSelectionEnabled;selectionClipboard;progressIndicatorEnabled;emergencyCleanupInstalled=!1;onProcessExit=null;onProcessSignal=null;onProcessUncaught=null;selectiveMouseSupported=!1;selectiveMouseProbing=!1;selectiveMouseProbeTimer=null;lastProgressState=0;readonly;constructor(e){this.term=e.term,this.dispatcher=e.dispatcher;let n=e.onKey;this.onKey=s=>{this.selection!==null&&s.length>0&&this.clearSelection(),n(s)},this.onBlockClick=e.onBlockClick,this.onMouse=e.onMouse,this.onBlockVisible=e.onBlockVisible,this.onSuspend=e.onSuspend,this.contentRepaintThrottleMs=e.repaintThrottleMs??dk,this.maxScrollbackLines=e.maxScrollbackLines??ck,this.mouseEnabled=e.mouse??!1,this.inAppSelectionEnabled=e.inAppSelection??this.mouseEnabled,this.selectionClipboard=e.selectionClipboard??"both",this.progressIndicatorEnabled=e.progressIndicator??!0,this.readonly=e.readonly??!1,this.resizeHandler=()=>this.repaint(),this.keyHandler=(s,r,i)=>this.handleKey(s,i),this.mouseHandler=(s,r)=>this.handleMouse(s,r),this.rawStdinHandler=s=>this.handleRawStdin(s)}start(e={}){this.started||(this.started=!0,e.skipFullscreen||this.term.fullscreen(!0),this.lastFrameRows.clear(),this.lastFrameW=0,this.lastFrameH=0,this.lastWindowTitle=null,process.stdout.write("\x1B[?7l"),this.mouseEnabled?this.term.grabInput({mouse:"drag"}):this.term.grabInput(!0),this.term.hideCursor(!1),this.term.on("key",this.keyHandler),this.mouseEnabled&&this.term.on("mouse",this.mouseHandler),this.term.on("resize",this.resizeHandler),this.installBracketedPaste(),this.installSelectiveMouseReporting(),this.installEmergencyCleanup(),this.lastProgressState=0,this.writeProgressIndicator(this.banner.status==="busy"?3:0),this.repaint())}stop(e={}){this.started&&(this.bannerNotificationTimer&&(clearTimeout(this.bannerNotificationTimer),this.bannerNotificationTimer=null),this.throttledRepaintTimer&&(clearTimeout(this.throttledRepaintTimer),this.throttledRepaintTimer=null),this.uninstallSelectiveMouseReporting(),this.uninstallBracketedPaste(),this.uninstallEmergencyCleanup(),this.term.off("key",this.keyHandler),this.mouseEnabled&&this.term.off("mouse",this.mouseHandler),this.term.off("resize",this.resizeHandler),this.term.grabInput(!1),this.term.hideCursor(!1),e.keepFullscreen||process.stdout.write("\x1B[?7h"),this.writeProgressIndicator(0),this.started=!1,e.keepFullscreen||(ua(),this.term.fullscreen(!1),this.term(`
|
|
153
173
|
`)))}installBracketedPaste(){process.stdout.write("\x1B[?2004h"),process.stdout.write("\x1B[>4;2m"),process.stdout.write("\x1B[>5;1m"),process.stdout.write("\x1B[>1u");let e=this.term;!e.stdin||typeof e.onStdin!="function"||(this.terminalKitStdinHandler=e.onStdin,e.stdin.removeListener("data",e.onStdin),e.stdin.on("data",this.rawStdinHandler))}uninstallBracketedPaste(){process.stdout.write("\x1B[?2004l"),process.stdout.write("\x1B[>4;0m"),process.stdout.write("\x1B[>5;0m"),process.stdout.write("\x1B[<u"),process.stdout.write("\x1B[?1l"),process.stdout.write("\x1B>");let e=this.term;!e.stdin||this.terminalKitStdinHandler===null||(e.stdin.removeListener("data",this.rawStdinHandler),e.stdin.on("data",this.terminalKitStdinHandler),this.terminalKitStdinHandler=null,this.pasteActive=!1,this.pasteBuffer="")}installSelectiveMouseReporting(){this.mouseEnabled||this.selectiveMouseProbing||this.selectiveMouseSupported||(this.selectiveMouseProbing=!0,process.stdout.write("\x1B[?w"),this.selectiveMouseProbeTimer=setTimeout(()=>{this.selectiveMouseProbing=!1,this.selectiveMouseProbeTimer=null},250))}uninstallSelectiveMouseReporting(){this.selectiveMouseProbeTimer&&(clearTimeout(this.selectiveMouseProbeTimer),this.selectiveMouseProbeTimer=null),this.selectiveMouseProbing=!1,this.selectiveMouseSupported&&(process.stdout.write("\x1B[=0;0w"),this.selectiveMouseSupported=!1)}installEmergencyCleanup(){this.emergencyCleanupInstalled||(this.emergencyCleanupInstalled=!0,this.onProcessExit=()=>ua(),this.onProcessSignal=e=>{ua(),process.off(e,this.onProcessSignal),process.kill(process.pid,e)},this.onProcessUncaught=e=>{ua(),process.stderr.write(`
|
|
154
174
|
uncaught: ${e.stack??e.message}
|
|
155
175
|
`),process.exit(1)},process.on("exit",this.onProcessExit),process.on("SIGTERM",this.onProcessSignal),process.on("SIGHUP",this.onProcessSignal),process.on("uncaughtException",this.onProcessUncaught))}uninstallEmergencyCleanup(){this.emergencyCleanupInstalled&&(this.emergencyCleanupInstalled=!1,this.onProcessExit&&(process.off("exit",this.onProcessExit),this.onProcessExit=null),this.onProcessSignal&&(process.off("SIGTERM",this.onProcessSignal),process.off("SIGHUP",this.onProcessSignal),this.onProcessSignal=null),this.onProcessUncaught&&(process.off("uncaughtException",this.onProcessUncaught),this.onProcessUncaught=null))}consumeSelectiveMouseSequences(e){if(!e.includes("\x1B["))return e;if(this.selectiveMouseProbing){let a=/\x1b\[\?(\d+);(\d+) w/.exec(e);a&&(this.selectiveMouseProbing=!1,this.selectiveMouseProbeTimer&&(clearTimeout(this.selectiveMouseProbeTimer),this.selectiveMouseProbeTimer=null),this.selectiveMouseSupported=!0,process.stdout.write("\x1B[=24;1w"),e=e.slice(0,a.index)+e.slice(a.index+a[0].length))}if(!this.selectiveMouseSupported)return e;let n=/\x1b\[<(64|65);\d+;\d+M/g,s="",r=0,i;for(;(i=n.exec(e))!==null;)s+=e.slice(r,i.index),i[1]==="64"?this.scrollBy(3):this.scrollBy(-3),r=i.index+i[0].length;return s+=e.slice(r),s}handleRawStdin(e){let n=e.toString("binary");if(n=this.consumeSelectiveMouseSequences(n),n.length!==0){if(this.pasteActive){this.handleRawStdinSegment(n);return}if(n===""&&this.onSuspend){this.onSuspend();return}if(/\x1b\[27;\d+;\d+~/.test(n)){this.handleCsi27Stdin(n);return}if(n.includes("\x1B[200~")){this.handleRawStdinSegment(n);return}if(n.includes(`
|
|
156
176
|
`)){let s=n.split(`
|
|
157
|
-
`);if(s.filter(i=>i.length>0).length>1){this.onKey([{type:"paste",text:n.replace(/\r/g,"")}]);return}for(let i=0;i<s.length;i++)s[i].length>0&&this.handleRawStdin(Buffer.from(s[i],"binary")),i<s.length-1&&this.onKey([{type:"key",name:"ctrl-enter"}]);return}if(n.includes("\x1B[")&&/\x1b\[\d+(?:;\d+)?u/.test(n)){this.handleCsiUStdin(n);return}this.handleRawStdinSegment(n)}}handleCsi27Stdin(e){let n=/\x1b\[27;(\d+);(\d+)~/g,s=0,r;for(;(r=n.exec(e))!==null;){r.index>s&&this.handleRawStdin(Buffer.from(e.slice(s,r.index),"binary"));let i=parseInt(r[1],10),o=parseInt(r[2],10),a=
|
|
158
|
-
`);this.pasteBuffer="";let a=
|
|
159
|
-
`),[o,...a]=i,d=0;if(this.streamingActive&&this.lines.length>0){let l=this.lines[this.lines.length-1];if(l){let f=this.wrappedRowsOf(l);this.forgetLine(l),l.body+=o??"",d+=this.wrappedRowsOf(l)-f}}else{if(this.lines.length>0){let f=this.lines[this.lines.length-1];if(!(f&&f.body===""&&(!f.prefix||f.prefix===""))){let p={body:""};this.lines.push(p),this.trackLine(p),d+=this.wrappedRowsOf(p)}}let l={prefix:n,body:o??"",bodyStyle:s};r!==void 0&&(l.prefixStyle=r),this.lines.push(l),this.trackLine(l),d+=this.wrappedRowsOf(l)}let c=" ".repeat(n.length);for(let l of a){let f={prefix:c,body:l,bodyStyle:s};this.lines.push(f),this.trackLine(f),d+=this.wrappedRowsOf(f)}this.streamingActive=!0,this.adjustScrollForRowChange(d),this.moveStickyToEnd(),this.trimScrollback(),this.scheduleRepaint()}setSessionbar(e){this.sessionbar={...this.sessionbar,...e},this.syncWindowTitle(),this.repaint()}syncWindowTitle(){let e=this.sessionbar.title?.trim(),n=
|
|
160
|
-
`)}selectionLineBounds(){let e=this.selection;if(e===null)return null;let n=this.lineIndexById(e.startLineId),s=this.lineIndexById(e.endLineId);if(n===-1||s===-1)return null;let r=n,i=s,o=e.startOffset,a=e.endOffset;n>s&&(r=s,i=n,o=e.endOffset,a=e.startOffset);let d=new Map;for(let c=r;c<=i;c++){let l=this.lines[c];if(!l)continue;let f=this.lineIds.get(l);if(f===void 0)continue;let u=(l.body??"").length,p=c===r?Math.max(0,Math.min(u,o)):0,g=c===i?Math.max(0,Math.min(u,a)):u;d.set(f,{start:p,end:g,toEnd:c<i})}return{loIdx:r,hiIdx:i,byId:d}}selectionRangeForChunk(e){if(this.selection===null||e.ansi)return null;let n=this.selectionRenderBounds??this.selectionLineBounds()?.byId??null;if(n===null)return null;let s=this.wrapOrigin.get(e);if(!s)return null;let r=n.get(s.sourceLineId);if(!r)return null;let i=s.sourceColOffset,o=i+e.body.length,a=Math.max(r.start,i),d=Math.min(r.end,o);return d<=a?null:{start:a-i,end:d-i,toEndOfLine:r.toEnd||r.end>o}}setBannerSearchIndicator(e){this.bannerSearchIndicator!==e&&(this.bannerSearchIndicator=e,this.syncedPartialRepaint(()=>this.drawBanner()))}bannerRightContent(){if(this.scrollbackSearch!==null){let e=this.scrollbackSearch,n=e.matches.length>0?` ${e.matchIndex+1}/${e.matches.length}`:e.term.length===0?"":" 0/0";return{text:`\u{1F50D} ${e.term}${n}`,kind:"search"}}return this.bannerSearchIndicator!==null?{text:`\u{1F50D} ${this.bannerSearchIndicator}`,kind:"search"}:this.bannerNotification!==null?{text:this.bannerNotification,kind:"notify"}:null}clearScrollback(){this.lines=[],this.keyedBlocks.clear(),this.wrapCache.clear(),this.wrapCacheWidth=0,this.streamingActive=!1,this.scrollOffset=0,this.selection!==null&&(this.selection=null),this.repaint()}invalidateSelectionIfTouches(e){if(this.selection!==null)for(let n of e){let s=this.lineIds.get(n);if(s!==void 0&&(s===this.selection.startLineId||s===this.selection.endLineId)){this.selection=null;return}}}setHideThoughts(e){this.hideThoughts!==e&&(this.hideThoughts=e,this.repaint())}clearKey(e){this.keyedBlocks.delete(e)}hasKey(e){return this.keyedBlocks.has(e)}removeKey(e){let n=this.keyedBlocks.get(e);if(!n)return;let s=n.start+n.count,r=s>=this.lines.length,i=this.wrappedRowsOfMany(this.lines.slice(n.start,s)),o=this.lines.splice(n.start,n.count);for(let a of o)this.forgetLine(a);this.invalidateSelectionIfTouches(o),this.keyedBlocks.delete(e);for(let[a,d]of this.keyedBlocks)a!==e&&d.start>n.start&&(d.start-=n.count);r&&(this.streamingActive=!1),this.adjustScrollForRowChange(-i),this.moveStickyToEnd(),this.scheduleRepaint()}setStickyBottomKey(e){this.stickyBottomKey=e,this.moveStickyToEnd(),this.scheduleRepaint()}moveStickyToEnd(){if(this.stickyBottomKey===null)return;let e=this.keyedBlocks.get(this.stickyBottomKey);if(!e)return;let n=e.start+e.count;if(n>=this.lines.length)return;let s=this.lines.splice(e.start,e.count);for(let[r,i]of this.keyedBlocks)r!==this.stickyBottomKey&&i.start>=n&&(i.start-=e.count);e.start=this.lines.length,this.lines.push(...s),this.streamingActive=!1}removeBlock(e){let n=this.keyedBlocks.get(e);if(!n)return;let s=n.start+n.count>=this.lines.length,r=this.wrappedRowsOfMany(this.lines.slice(n.start,n.start+n.count)),i=this.lines.splice(n.start,n.count);for(let o of i)this.forgetLine(o);this.invalidateSelectionIfTouches(i),this.keyedBlocks.delete(e);for(let[,o]of this.keyedBlocks)o.start>n.start&&(o.start-=n.count);s&&(this.streamingActive=!1),this.adjustScrollForRowChange(-r),this.scheduleRepaint()}contiguousRun(e,n){if(!this.keyedBlocks.has(e))return[];let s=[...n].map(d=>{let c=this.keyedBlocks.get(d);return c?{key:d,start:c.start,count:c.count}:null}).filter(d=>d!==null).sort((d,c)=>d.start-c.start),r=s.findIndex(d=>d.key===e);if(r<0)return[];let i=(d,c)=>{for(let[l,f]of this.keyedBlocks)if(!n.has(l)&&f.start>=d&&f.start<c)return!0;return!1},o=r;for(;o>0&&!i(s[o-1].start+s[o-1].count,s[o].start);)o--;let a=r;for(;a<s.length-1&&!i(s[a].start+s[a].count,s[a+1].start);)a++;return s.slice(o,a+1).map(d=>d.key)}setRunCollapsed(e,n,s){if(e.length===0)return;let r=e[0];if(!this.keyedBlocks.has(r))return;this.upsertLines(r,s);let i=this.keyedBlocks.get(r),o=i.start+i.count;for(let a of e){let d=this.keyedBlocks.get(a);d&&(o=Math.max(o,d.start+d.count))}for(let a=i.start+i.count;a<o;a++){let d=this.lines[a];d&&(d.collapsed=n)}this.scheduleRepaint()}redraw(){this.repaint()}fullRedraw(){this.lastFrameRows.clear(),this.lastFrameW=0,this.lastFrameH=0,this.lastWindowTitle=null,this.wrapCache.clear(),this.wrapCacheWidth=0,process.stdout.write("\x1B[?7l"),this.term.clear(),this.repaint()}pauseRepaint(){this.repaintPaused+=1}resumeRepaint(){this.repaintPaused!==0&&(this.repaintPaused-=1,this.repaintPaused===0&&this.repaintPending&&(this.repaintPending=!1,this.repaint()))}setQueuedPrompts(e){this.queuedTexts=[...e],this.lastQueueEditingIndex=this.dispatcher.state().queueIndex,this.repaint()}repaintNow(){this.repaint()}setPermissionPrompt(e){e!==null&&this.permissionPrompt===null&&this.clearSelection(),this.permissionPrompt=e?{...e}:null,this.repaint()}setOptionsPrompt(e){e!==null&&this.optionsPrompt===null&&this.clearSelection(),this.optionsPrompt=e?{...e,options:e.options.map(n=>({...n}))}:null,this.repaint()}isOptionsPromptActive(){return this.optionsPrompt!==null}setConfirmPrompt(e){e!==null&&this.confirmPrompt===null&&this.clearSelection(),this.confirmPrompt=e?{...e}:null,this.repaint()}setHelpPrompt(e){e!==null&&this.helpPrompt===null&&this.clearSelection(),this.helpPrompt=e?{...e,entries:[...e.entries]}:null,this.repaint()}isHelpPromptActive(){return this.helpPrompt!==null}setCompletions(e){e.length===this.completions.length&&e.every((s,r)=>{let i=this.completions[r];return i!==void 0&&i.name===s.name&&i.description===s.description})||(this.completions=[...e],this.repaint())}ensureSeparator(e){if(this.lines.length===0)return;let n=this.stickyBottomKey!==null?this.keyedBlocks.get(this.stickyBottomKey):void 0,s=n!==void 0&&n.start+n.count===this.lines.length,r=s?n.start-1:this.lines.length-1;if(r<0)return;let i=this.lines[r];if(i&&i.body===""&&(i.prefix===void 0||i.prefix===""))return;let o={body:""};e!==void 0&&(o.bodyStyle=e),s?(this.lines.splice(n.start,0,o),n.start+=1):this.lines.push(o),this.trackLine(o),this.streamingActive=!1,this.adjustScrollForRowChange(this.wrappedRowsOf(o)),this.trimScrollback(),this.scheduleRepaint()}refreshPrompt(){if(this.promptRows()!==this.lastPromptRows){this.repaint();return}this.syncedPartialRepaint(()=>{let e=this.dispatcher.state().queueIndex;e!==this.lastQueueEditingIndex&&(this.lastQueueEditingIndex=e,this.drawQueuedZone()),this.drawPrompt()})}handleKey(e,n){if(n.isCharacter){this.onKey([{type:"char",ch:e}]);return}if(e==="PAGE_UP"){this.scrollBy(this.scrollPageSize());return}if(e==="PAGE_DOWN"){this.scrollBy(-this.scrollPageSize());return}let s=ha(e);s&&this.onKey([{type:"key",name:s}])}handleMouse(e,n){if(e==="MOUSE_WHEEL_UP"){this.scrollBy(3);return}if(e==="MOUSE_WHEEL_DOWN"){this.scrollBy(-3);return}let s=this.mouseCell(n),r=uk(e),i=null;if(e==="MOUSE_DRAG"||e==="MOUSE_MOTION"?i="move":e.endsWith("_PRESSED")?i="press":e.endsWith("_RELEASED")&&(i="release"),i!==null&&s!==null&&this.onMouse&&this.onMouse({kind:i,button:r,x:s.x,y:s.y,name:e}),e==="MOUSE_LEFT_BUTTON_PRESSED"){this.pressCell=s,this.handleSelectionPress(s);return}if(e==="MOUSE_DRAG"&&s!==null){this.handleSelectionDrag(s);return}if(e==="MOUSE_LEFT_BUTTON_RELEASED"||e==="MOUSE_BUTTON_RELEASED"){let o=this.pressCell;this.pressCell=null;let a=this.inAppSelectionEnabled&&(this.selectionDragStarted||this.doubleClickPending);if(this.onBlockClick&&o!==null&&s!==null&&s.x===o.x&&s.y===o.y&&!a){let d=this.keyAtRow(s.y);d!==null&&this.onBlockClick(d)}this.handleSelectionRelease(s)}}handleSelectionPress(e){if(this.selectionAnchor=null,this.selectionDragStarted=!1,this.doubleClickPending=!1,!this.inAppSelectionEnabled||e===null)return;let n=this.resolveCellToSource(e.x,e.y);if(n===null){this.lastLeftClick=null;return}this.selectionAnchor=n;let s=Date.now(),r=this.lastLeftClick;if(r!==null&&s-r.t<=nk&&Math.abs(e.x-r.x)<=Jm&&Math.abs(e.y-r.y)<=Jm){let o=this.wordBoundsAt(n);o!==null&&(this.setSelection({sourceLineId:n.sourceLineId,offset:o.start},{sourceLineId:n.sourceLineId,offset:o.end}),this.doubleClickPending=!0),this.lastLeftClick=null}}handleSelectionDrag(e){if(!this.inAppSelectionEnabled||this.selectionAnchor===null||this.doubleClickPending)return;let n=this.resolveCellToSource(e.x,e.y);n!==null&&(this.selectionDragStarted=!0,this.setSelection(this.selectionAnchor,n))}handleSelectionRelease(e){let n=this.selectionDragStarted,s=this.doubleClickPending;if(this.selectionAnchor=null,this.selectionDragStarted=!1,this.doubleClickPending=!1,e!==null&&(this.lastLeftClick={x:e.x,y:e.y,t:Date.now()}),!!this.inAppSelectionEnabled){if(n||s){this.finalizeSelection();return}this.selection!==null&&this.clearSelection()}}wordBoundsAt(e){let n=this.lineById(e.sourceLineId);if(n===null||n.ansi)return null;let s=n.body??"";if(s.length===0)return null;let r=Math.max(0,Math.min(s.length-1,e.offset));if(e.offset>=s.length&&(r=s.length-1),!pc.test(s[r]))return null;let i=r;for(;i>0&&pc.test(s[i-1]);)i--;let o=r+1;for(;o<s.length&&pc.test(s[o]);)o++;return{start:i,end:o}}lineById(e){for(let n of this.lines)if(this.lineIds.get(n)===e)return n;return null}lineIndexById(e){for(let n=0;n<this.lines.length;n++){let s=this.lines[n];if(s&&this.lineIds.get(s)===e)return n}return-1}finalizeSelection(){let e=this.getSelectionText();e.length!==0&&qm(e,{target:this.selectionClipboard}).then(n=>{if(n.ok){let s=e.length;this.notify(`copied ${s} char${s===1?"":"s"} to clipboard`)}else this.notify(`clipboard copy failed: ${n.reason}`)},n=>{this.notify(`clipboard copy failed: ${n.message}`)})}mouseCell(e){if(!e||typeof e!="object")return null;let n=e,s=Number(n.x),r=Number(n.y);return!Number.isFinite(s)||!Number.isFinite(r)?null:{x:s,y:r}}keyAtRow(e){let n=this.term.width,s=1,r=this.scrollbackVisibleRows();if(r<=0)return null;let i=e-s;if(i<0||i>=r)return null;let{rows:o}=this.wrapTail(n,r+this.scrollOffset),a=o.length-this.scrollOffset,d=Math.max(0,a-r),c=o.slice(d,a),l=Math.max(0,r-c.length),f=i-l;return f<0||f>=c.length?null:c[f]?.blockKey??null}resolveCellToSource(e,n){if(!Number.isFinite(e)||!Number.isFinite(n))return null;let s=this.term.width,r=1,i=this.scrollbackVisibleRows();if(i<=0)return null;let o=n-r;if(o<0||o>=i||e<1||e>s)return null;let{rows:a}=this.wrapTail(s,i+this.scrollOffset),d=a.length-this.scrollOffset,c=Math.max(0,d-i),l=a.slice(c,d),f=Math.max(0,i-l.length),u=o-f;if(u<0||u>=l.length)return null;let p=l[u];if(!p)return null;let g=this.wrapOrigin.get(p);if(!g)return null;let h=jn(p.prefix??""),w=e-1-h;if(w<0)return{sourceLineId:g.sourceLineId,offset:g.sourceColOffset};let v=ca(p.bodyStyle)?Bm(vc(p.body),w):Lm(p.body,w);return{sourceLineId:g.sourceLineId,offset:g.sourceColOffset+v}}scrollBy(e){if(e===0)return;this.scrollbackSearch!==null&&this.acceptScrollbackSearch();let n=this.maxScrollOffset(),s=Math.min(n,Math.max(0,this.scrollOffset+e));s!==this.scrollOffset&&(this.scrollOffset=s,this.repaint())}scrollToBottom(){this.scrollbackSearch!==null&&this.acceptScrollbackSearch(),this.scrollOffset!==0&&(this.scrollOffset=0,this.repaint())}scrollToTop(){this.scrollbackSearch!==null&&this.acceptScrollbackSearch();let e=this.maxScrollOffset();this.scrollOffset!==e&&(this.scrollOffset=e,this.repaint())}isScrolledBack(){return this.scrollOffset>0}isScrollbackSearchActive(){return this.scrollbackSearch!==null}enterScrollbackSearch(){this.scrollbackSearch===null&&(this.scrollbackSearch={term:"",matchIndex:0,matches:[],baselineScroll:this.scrollOffset},this.scrollbackHighlight=null,this.repaint())}updateScrollbackSearchTerm(e){if(this.scrollbackSearch===null)return;let n=e.toLowerCase(),s=[];if(n.length>0)for(let r=this.lines.length-1;r>=0;r--){let i=this.lines[r];if(!i||i.body.length===0||i.ansi)continue;let o=i.body.toLowerCase(),a=[],d=0;for(;d<o.length;){let c=o.indexOf(n,d);if(c===-1)break;a.push(c),d=c+n.length}for(let c=a.length-1;c>=0;c--)s.push({lineIdx:r,col:a[c]})}this.scrollbackSearch.term=e,this.scrollbackSearch.matches=s,this.scrollbackSearch.matchIndex=0,this.scrollbackHighlight=n.length>0?n:null,s.length>0&&this.scrollToMatch(s[0]),this.repaint()}advanceScrollbackSearch(){if(this.scrollbackSearch===null||this.scrollbackSearch.matches.length===0)return;let e=Math.min(this.scrollbackSearch.matches.length-1,this.scrollbackSearch.matchIndex+1);e!==this.scrollbackSearch.matchIndex&&(this.scrollbackSearch.matchIndex=e,this.scrollToMatch(this.scrollbackSearch.matches[e]),this.repaint())}retreatScrollbackSearch(){this.scrollbackSearch===null||this.scrollbackSearch.matches.length===0||this.scrollbackSearch.matchIndex!==0&&(this.scrollbackSearch.matchIndex-=1,this.scrollToMatch(this.scrollbackSearch.matches[this.scrollbackSearch.matchIndex]),this.repaint())}acceptScrollbackSearch(){this.scrollbackSearch!==null&&(this.scrollbackSearch=null,this.scrollbackHighlight=null,this.repaint())}cancelScrollbackSearch(){if(this.scrollbackSearch===null)return;let e=this.scrollbackSearch.baselineScroll;this.scrollbackSearch=null,this.scrollbackHighlight=null,this.scrollOffset=e,this.repaint()}scrollbackSearchTerm(){return this.scrollbackSearch?.term??""}currentMatchInfo(){if(this.scrollbackSearch===null||this.scrollbackSearch.matches.length===0)return null;let e=this.scrollbackSearch.matches[this.scrollbackSearch.matchIndex];if(!e)return null;let n=this.lines[e.lineIdx];if(!n)return null;let s=this.lineIds.get(n);return s===void 0?null:{lineId:s,col:e.col,length:this.scrollbackSearch.term.length}}activeMatchCol(e,n){if(!e||n===null)return null;let s=this.wrapOrigin.get(e);if(!s||s.sourceLineId!==n.lineId)return null;let r=n.col-s.sourceColOffset;return r<0||r>=e.body.length?null:r}scrollToMatch(e){let n=this.term.width,s=this.scrollbackVisibleRows();if(s<=0)return;let r=0;for(let l=this.lines.length-1;l>e.lineIdx;l--){let f=this.lines[l];f&&(r+=this.wrapOne(f,n).length)}let i=this.lines[e.lineIdx],o=0;if(i){let l=this.wrapOne(i,n),f=0;for(let u=0;u<l.length;u++){let p=l[u];if(!p)continue;let g=p.body.length;if(e.col<f+g){o=l.length-1-u;break}f+=g}}let a=r+o,d=Math.max(0,a-Math.floor(s/2)),c=this.maxScrollOffset();this.scrollOffset=Math.min(c,d)}scrollPageSize(){return Math.max(1,this.scrollbackVisibleRows()-2)}scrollbackVisibleRows(){let n=this.term.height-this.promptRows()-je-qe-Ye-qe-this.chipRows()-this.queuedRows()-this.completionRows();return Math.max(0,n-1+1)}maxScrollOffset(){let{rows:e}=this.wrapTail(this.term.width,Number.POSITIVE_INFINITY);return Math.max(0,e.length-this.scrollbackVisibleRows())}scheduleRepaint(){if(!this.started)return;if(this.repaintPaused>0){this.repaintPending=!0;return}if(this.contentRepaintThrottleMs<=0){this.repaint();return}let n=Date.now()-this.lastRepaintAt;if(n>=this.contentRepaintThrottleMs){this.throttledRepaintTimer&&(clearTimeout(this.throttledRepaintTimer),this.throttledRepaintTimer=null),this.repaint();return}this.throttledRepaintTimer===null&&(this.throttledRepaintTimer=setTimeout(()=>{this.throttledRepaintTimer=null,this.repaint()},this.contentRepaintThrottleMs-n))}paintRow(e,n,s){this.started&&(e<1||e>this.term.height||this.lastFrameRows.get(e)!==n&&(this.lastFrameRows.set(e,n),this.term.moveTo(1,e),s(),this.term.styleReset(),this.term.eraseLineAfter()))}repaint(){if(!this.started)return;if(this.repaintPaused>0){this.repaintPending=!0;return}this.lastRepaintAt=Date.now(),this.throttledRepaintTimer&&(clearTimeout(this.throttledRepaintTimer),this.throttledRepaintTimer=null);let e=this.term.width,n=this.term.height;e<20||n<8||((e!==this.lastFrameW||n!==this.lastFrameH)&&(this.lastFrameRows.clear(),this.lastFrameW=e,this.lastFrameH=n),Pe(()=>{this.term.hideCursor(),this.drawScrollback(),this.drawCompletionZone(),this.drawQueuedZone(),this.drawAttachmentChipZone();let s=this.promptRows(),r=n-s-Ye-qe-je;this.drawSeparator(r),this.drawPrompt(),this.drawBanner(),this.drawSeparator(n-je),this.drawSessionbar(),this.placeCursor(),(this.permissionPrompt||this.optionsPrompt||this.confirmPrompt||this.helpPrompt)&&this.term.hideCursor(!1),this.lastPromptRows=s}))}drawSessionbar(){let e=this.term.width,n=this.term.height,s=Qm(this.sessionbar.sessionId),r=this.sessionbar.title?.trim(),i=up(this.sessionbar.agent,this.sessionbar.model),o=Be(this.sessionbar.cwd),a=Sk(this.sessionbar.usage),d=`sbar|${e}|${s}|${i}|${o}|${r??""}|${a??""}`;this.paintRow(n,d,()=>{let c=a?a.length+3:0,l=s.length+3+i.length+3+(r?3:0)+c,f=Math.max(8,e-l),u,p;if(r){let g=Math.min(r.length,8);u=Math.min(o.length,Math.max(8,f-g)),p=Math.max(0,f-u)}else p=0,u=f;if(this.term.yellow(s)(" \xB7 ").cyan.noFormat(i)(" \xB7 ").dim.noFormat(ot(o,u)),r&&this.term(" \xB7 ").bold.noFormat(ot(r,p)),this.term.eraseLineAfter(),a){let g=fa(a),h=Math.max(1,e-g);this.term.moveTo(h,n).eraseLineAfter(),this.term.dim.noFormat(a)}})}drawSeparator(e){let n=this.term.width;this.paintRow(e,`sep|${n}`,()=>{this.term.dim("\u2500".repeat(n))})}drawScrollback(){let e=this.term.width,n=1,s=this.scrollbackVisibleRows();if(s<=0)return;let{rows:r,exhausted:i}=this.wrapTail(e,s+this.scrollOffset);if(i){let u=Math.max(0,r.length-s);this.scrollOffset>u&&(this.scrollOffset=u)}let o=r.length-this.scrollOffset,a=Math.max(0,o-s),d=r.slice(a,o),c=Math.max(0,s-d.length),l=this.currentMatchInfo(),f=l?.length??0;this.selectionRenderBounds=this.selectionLineBounds()?.byId??null;for(let u=0;u<s;u++){let p=n+u,g=u-c,h=g>=0?d[g]:void 0,w=this.activeMatchCol(h,l),v=h?this.selectionRangeForChunk(h):null,b=fk("sb",e,h,this.scrollbackHighlight,w,v);this.paintRow(p,b,()=>{h&&this.writeFormattedLine(h,e,w,f,v)})}if(this.onBlockVisible&&this.pendingVisibleKeys.size>0){let u=new Set;for(let g of d)g.blockKey!==void 0&&u.add(g.blockKey);let p=[];for(let g of this.pendingVisibleKeys)u.has(g)&&p.push(g);for(let g of p)this.pendingVisibleKeys.delete(g),this.onBlockVisible(g)}}notifyWhenVisible(e){this.onBlockVisible&&(this.pendingVisibleKeys.add(e),this.scheduleRepaint())}queuedRows(){return Math.min(hc,this.queuedTexts.length)}chipRows(){return Math.min(yc,this.attachments.length)}setAttachments(e){this.attachments.length===e.length&&this.attachments.every((n,s)=>n===e[s])||(this.attachments=[...e],this.repaint())}completionRows(){return this.permissionPrompt||this.optionsPrompt||this.confirmPrompt||this.helpPrompt?0:Math.min(gc,this.completions.length)}drawCompletionZone(){let e=this.completionRows();if(e===0)return;let n=this.term.width,s=this.promptRows(),r=this.term.height-s-je-qe-Ye,i=this.queuedRows(),o=this.chipRows(),d=r-1-i-o-e+1,c=0;for(let l of this.completions.slice(0,e))l.name.length>c&&(c=l.name.length);for(let l=0;l<e;l++){let f=d+l,u=this.completions[l],p=l===e-1&&this.completions.length>gc,g=this.completions.length-gc+1,h=u?p?`comp|${n}|overflow|${g}`:`comp|${n}|${c}|${u.name}|${u.description??""}`:`comp|${n}|empty`;this.paintRow(f,h,()=>{if(!u)return;if(p){this.term.dim(` + ${g} more match(es)`);return}let w=u.name.padEnd(c),v=u.description??"",b=n-w.length-4,x=b>0?ot(v,b):"";this.term(" ").brightCyan(w),x.length>0&&this.term(" ").dim(x)})}}drawAttachmentChipZone(){let e=this.chipRows();if(e===0)return;let n=this.term.width,s=this.promptRows(),o=this.term.height-s-je-qe-Ye-1-e+1,a=this.isIterm2();for(let d=0;d<e;d++){let c=o+d,l=d===e-1&&this.attachments.length>yc,f=this.attachments.length-yc,u=this.attachments[d],p=u?`${u.name??"image"} \xB7 ${Et(u.sizeBytes)}`:"",g=l?`chip|${n}|overflow|${f}`:u?`chip|${n}|${a?"i":"t"}|${p}|${u.sizeBytes}`:`chip|${n}|empty`;this.paintRow(c,g,()=>{if(l){this.term.dim(` \u{1F4CE} + ${f+1} more attached`);return}u&&(this.term(" ").yellow(`\u{1F4CE} ${p}`),a&&(this.term(" "),this.writeIterm2Image(u.data,1)))})}}isIterm2(){let e=process.env;return e.LC_TERMINAL==="iTerm2"||e.TERM_PROGRAM==="iTerm.app"}writeIterm2Image(e,n){process.stdout.write(gk(e,n,!!process.env.TMUX))}drawQueuedZone(){let e=this.queuedRows();if(e===0)return;let n=this.term.width,s=this.promptRows(),r=this.term.height-s-je-qe-Ye,i=this.chipRows(),a=r-1-i-e+1,d=this.dispatcher.state().queueIndex;for(let c=0;c<e;c++){let l=a+c,f=this.queuedTexts[c],u=c===e-1&&this.queuedTexts.length>hc,p=this.queuedTexts.length-hc,g=f===void 0?"":u?`+ ${p+1} more queued`:ot(Ik(f),n-4),h=!u&&c===d,w=f===void 0?`queued|${n}|empty`:`queued|${n}|${h?"edit":u?"ovf":"row"}|${g}`;this.paintRow(l,w,()=>{if(f===void 0)return;let v=`\u23F3 ${g}`,b=v+" ".repeat(Math.max(0,n-1-v.length));h?this.term.bgBlue.brightYellow("\u25B8"):this.term.bgBlue(" "),this.term.bgBlue.brightWhite.noFormat(b)})}}drawPrompt(){if(this.permissionPrompt){this.drawPermissionPrompt();return}if(this.optionsPrompt){this.drawOptionsPrompt();return}if(this.confirmPrompt){this.drawConfirmPrompt();return}if(this.helpPrompt){this.drawHelpPrompt();return}if(this.readonly)return;let e=this.term.width,n=Math.max(1,e-2),s=this.dispatcher.state(),r=pn(s.buffer,n),i=qn(r,s,mc),o=this.term.height-i.rendered-Ye-qe-je+1;for(let a=0;a<i.rendered;a++){let d=r[i.windowStart+a],c=o+a,l="wrap",f="";d&&(d.bufferIdx===0&&d.startCol===0?l="first":d.startCol===0&&(l="newline"),f=(s.buffer[d.bufferIdx]??"").slice(d.startCol,d.endCol));let u=d?`prompt|${this.term.width}|${l}|${f}`:`prompt|${this.term.width}|empty`;this.paintRow(c,u,()=>{d&&(l==="first"?this.term.brightWhite("> "):l==="newline"?this.term.dim("\xB7 "):this.term(" "),this.term.noFormat(f))})}}drawConfirmPrompt(){let e=this.confirmPrompt;if(!e)return;let n=this.term.width,s=this.term.height-wc-Ye-qe-je+1;this.paintRow(s,`confirm|q|${n}|${e.question}`,()=>{this.term.brightYellow(` ? ${ot(e.question,n-4)}`)}),this.paintRow(s+1,`confirm|h|${n}|${e.hint}`,()=>{this.term.dim(` ${ot(e.hint,n-2)}`)})}drawHelpPrompt(){let e=this.helpPrompt;if(!e)return;let n=this.term.width,s=this.helpRows(),r=this.term.height-s-Ye-qe-je+1,i=r,o=(d,c)=>{i>=r+s||(this.paintRow(i,d,c),i+=1)};o(`help|t|${n}|${e.title}`,()=>{this.term.brightYellow(` \u2753 ${ot(e.title,n-5)}`)});let a=Math.min(24,Math.max(...e.entries.map(d=>d===null?0:d[0].length),4));for(let d of e.entries){if(i>=r+s-1)break;if(d===null){o(`help|sep|${n}|${i}`,()=>{});continue}let[c,l]=d,f=c.padEnd(a);o(`help|e|${n}|${c}|${l}`,()=>{this.term(" "),this.term.brightCyan.noFormat(f),this.term.noFormat(` ${ot(l,n-2-a-1)}`)})}o(`help|hint|${n}|${e.hint}`,()=>{this.term.dim(` ${ot(e.hint,n-2)}`)})}helpRows(){return this.helpPrompt?Math.min(ok,2+this.helpPrompt.entries.length):0}drawPermissionPrompt(){let e=this.permissionPrompt;if(!e)return;let n=this.term.width,s=this.permissionRows(),r=this.term.height-s-Ye-qe-je+1,i=r,o=(d,c)=>{i>=r+s||(this.paintRow(i,d,c),i+=1)};o(`perm|t|${n}|${e.title}`,()=>{this.term.brightYellow(` \u{1F512} ${ot(e.title,n-5)}`)});let a=e.detail&&e.detail.length>0?e.detail:"This action requires approval";o(`perm|sub|${n}|${a}`,()=>{this.term.dim(` ${ot(a,n-2)}`)}),o(`perm|q|${n}`,()=>{this.term(" Do you want to proceed?")});for(let d=0;d<e.options.length&&!(i>=r+s-1);d++){let c=e.options[d];if(!c)continue;let l=d===e.selectedIndex,u=` ${l?"\u276F":" "} ${d+1}. ${ot(c.label,n-8)}`;o(`perm|o|${n}|${d}|${l?"1":"0"}|${c.label}`,()=>{l?this.term.brightYellow(u):this.term.dim(u)})}o(`perm|hint|${n}`,()=>{this.term.dim(" \u2191/\u2193 choose \xB7 Enter submit \xB7 Esc cancel \xB7 1\u20139 quick-pick")})}drawBanner(){let e=this.term.height-je-qe,n=this.term.width,s=this.banner.status==="busy"&&this.banner.elapsedMs!==void 0&&this.banner.elapsedMs>=1e3?Gt(this.banner.elapsedMs):"",r=this.bannerRightContent(),i=r?`${r.kind}|${r.text}`:"",o=this.banner.status==="busy"&&this.banner.stalled===!0,a=`bnr|${n}|${this.banner.status}|${s}|${o?"1":"0"}|${this.banner.queued}|${this.scrollOffset}|${this.banner.currentMode??""}|${this.banner.hint}|`+i;this.paintRow(e,a,()=>{let d=this.banner.status==="busy"?"\u25CF":"\u25CB";this.banner.status==="busy"?(o?this.term.brightRed(`${d} stalled`):this.term.brightYellow(`${d} ${this.banner.status}`),s&&this.term(" ").dim(s)):this.banner.status==="disconnected"?this.term.brightRed(`${d} ${this.banner.status}`):this.banner.status==="cold"?this.term.brightMagenta(`${d} ${this.banner.status}`):this.term.brightGreen(`${d} ${this.banner.status}`),this.banner.queued>0&&this.term(" \xB7 ").brightYellow(`${this.banner.queued} queued`),this.scrollOffset>0&&this.term(" \xB7 ").brightCyan(`\u2191 ${this.scrollOffset}`);let c=this.banner.currentMode?this.banner.hint.replace("\u21E7\u21E5 mode",`\u21E7\u21E5 mode: ${this.banner.currentMode}`):this.banner.hint;if(this.term(" \xB7 ").dim(c),this.term.eraseLineAfter(),r){let l=fa(r.text),f=Math.max(1,n-l);this.term.moveTo(f,e).eraseLineAfter(),r.kind==="search"?this.term.brightCyan.noFormat(r.text):this.term.brightYellow.noFormat(r.text)}})}placeCursor(){if(!this.started)return;if(this.permissionPrompt){let l=this.permissionRows(),u=this.term.height-l-Ye-qe-je+1+3+this.permissionPrompt.selectedIndex,p=this.term.height-Ye-qe-je;this.term.moveTo(2,Math.min(u,p));return}if(this.optionsPrompt){let l=this.optionsRows(),u=this.term.height-l-Ye-qe-je+1+1+this.optionsPrompt.selectedIndex,p=this.term.height-Ye-qe-je;this.term.moveTo(2,Math.min(u,p));return}if(this.confirmPrompt){let l=this.term.height-wc-Ye-qe-je+1;this.term.moveTo(2,l);return}if(this.helpPrompt){let l=this.helpRows(),f=this.term.height-l-Ye-qe-je+1;this.term.moveTo(2,f);return}if(this.scrollbackSearch){this.term.hideCursor(!0);return}if(this.readonly){this.term.hideCursor(!0);return}this.term.hideCursor(!1);let e=this.term.width,n=Math.max(1,e-2),s=this.dispatcher.state(),r=pn(s.buffer,n),i=qn(r,s,mc),a=this.term.height-i.rendered-Ye-qe-je+1+Math.max(0,i.cursorVisualRow-i.windowStart),d=i.cursorVisualCol+3,c=this.term.height-Ye-qe-je;this.term.moveTo(Math.min(d,this.term.width),Math.min(a,c))}promptRows(){if(this.permissionPrompt)return this.permissionRows();if(this.optionsPrompt)return this.optionsRows();if(this.confirmPrompt)return wc;if(this.helpPrompt)return this.helpRows();if(this.readonly)return 0;let e=this.term.width,n=Math.max(1,e-2),s=this.dispatcher.state(),r=pn(s.buffer,n);return Math.min(mc,Math.max(1,r.length))}permissionRows(){return this.permissionPrompt?Math.min(rk,4+this.permissionPrompt.options.length):0}optionsRows(){return this.optionsPrompt?Math.min(ik,2+this.optionsPrompt.options.length):0}drawOptionsPrompt(){let e=this.optionsPrompt;if(!e)return;let n=this.term.width,s=this.optionsRows(),r=this.term.height-s-Ye-qe-je+1,i=r,o=(d,c)=>{i>=r+s||(this.paintRow(i,d,c),i+=1)};o(`opts|t|${n}|${e.title}`,()=>{this.term.brightYellow(` \u2699 ${ot(e.title,n-5)}`)});let a=Math.max(...e.options.map(d=>d.label.length),0);for(let d=0;d<e.options.length&&!(i>=r+s-1);d++){let c=e.options[d];if(!c)continue;let l=d===e.selectedIndex,u=` ${l?"\u276F":" "} ${d+1}. `,p=c.label.padEnd(a),g=n-u.length-3,h=`${u}${ot(`${p} ${c.value}`,g)}`;o(`opts|o|${n}|${d}|${l?"1":"0"}|${c.value}|${c.label}`,()=>{l?this.term.brightYellow(h):this.term.dim(h)})}o(`opts|hint|${n}`,()=>{this.term.dim(" \u2191/\u2193 choose \xB7 Enter this session \xB7 s save default \xB7 Esc close")})}wrapTail(e,n){let s=c=>c.collapsed===!0||this.hideThoughts&&c.bodyStyle==="thought";if(e<=4){let c=[];for(let f of this.lines)s(f)||c.push(f);let l=Math.min(n,c.length);return{rows:c.slice(c.length-l),exhausted:n>=c.length}}if(this.wrapCacheWidth!==e&&(this.wrapCache.clear(),this.wrapCacheWidth=e),n<=0||this.lines.length===0)return{rows:[],exhausted:!0};let r=[],i=0,o=0,a=!1;for(let c=this.lines.length-1;c>=0;c--){let l=this.lines[c];if(s(l)){c===0&&(a=!0);continue}let f=this.wrapOne(l,e);if(r.push(f),i+=f.length,o=c,i>=n)break}let d=[];for(let c=r.length-1;c>=0;c--)d.push(...r[c]);return{rows:d,exhausted:o===0||a}}wrapOne(e,n){let s=this.lineIds.get(e);if(s!==void 0){let f=this.wrapCache.get(s);if(f)return f}let r=e.prefix??"",i=jn(r),o=Math.max(1,n-i),a=ca(e.bodyStyle),d=e.ansi?pk(e.body,o):yk(e.body,o,{stripMarkup:a}),c=[],l=0;for(let f=0;f<d.length;f++){let u=d[f]??"",p={prefix:f===0?e.prefix:" ".repeat(i),body:u};if(e.prefixStyle!==void 0&&(p.prefixStyle=e.prefixStyle),e.bodyStyle!==void 0&&(p.bodyStyle=e.bodyStyle),e.blockKey!==void 0&&(p.blockKey=e.blockKey),e.fillRow&&(p.fillRow=!0),e.ansi&&(p.ansi=!0),f===0&&e.iterm2Image&&(p.iterm2Image=e.iterm2Image),s!==void 0&&u.length>0){let g=e.body.indexOf(u,l),h=g===-1?l:g;this.wrapOrigin.set(p,{sourceLineId:s,sourceColOffset:h}),l=h+u.length}c.push(p)}return s!==void 0&&this.wrapCache.set(s,c),c}writeFormattedLine(e,n,s=null,r=0,i=null){e.prefix&&fn(this.term,e.prefix,e.prefixStyle??e.bodyStyle);let o=Math.max(0,n-jn(e.prefix??"")),a=ca(e.bodyStyle),d=e.ansi?e.body:ot(e.body,o,{stripMarkup:a}),c=(l,f)=>{if(l.length!==0)if(this.scrollbackHighlight!==null&&!e.ansi){let u=s!==null&&s>=f?s-f:null;Km(this.term,l,e.bodyStyle,this.scrollbackHighlight,u,r)}else fn(this.term,l,e.bodyStyle)};if(i!==null&&!e.ansi){let l=Math.max(0,Math.min(d.length,i.start)),f=Math.max(l,Math.min(d.length,i.end));c(d.slice(0,l),0),f>l&&fn(this.term,d.slice(l,f),"selection-highlight"),c(d.slice(f),f)}else this.scrollbackHighlight!==null&&!e.ansi?Km(this.term,d,e.bodyStyle,this.scrollbackHighlight,s,r):fn(this.term,d,e.bodyStyle);if(e.fillRow){let l=e.ansi?fa(d):jn(d),f=o-l;if(f>0){let u=i!==null&&i.toEndOfLine?"selection-highlight":e.bodyStyle;fn(this.term," ".repeat(f),u)}}(e.ansi||e.body.includes("^"))&&this.term.styleReset(),e.iterm2Image&&this.isIterm2()&&this.writeIterm2Image(e.iterm2Image.data,e.iterm2Image.heightCells)}};Xm=/[^\x20-\x7e]/,bc=new Intl.Segmenter(void 0,{granularity:"grapheme"}),Zm=!1;mk=/[a-zA-Z+\-:_!#/]/;Qm=He});function Ir(){process.stdout.write("\x1B[<u"),process.stdout.write("\x1B[?2004l"),process.stdout.write("\x1B[>4;0m"),process.stdout.write("\x1B[>5;0m"),process.stdout.write("\x1B[?1000l"),process.stdout.write("\x1B[?1002l"),process.stdout.write("\x1B[?1006l"),process.stdout.write("\x1B[?1l"),process.stdout.write("\x1B>")}function Sc(t){return t.width??80}function kc(t){return t.height??24}function ys(t,e){let n=Sc(t),s=kc(t),r=e.contentWidth??64,i=Math.max(10,n-4),o=Math.min(r,i),a=o+2,d=Math.max(1,Math.min(e.contentHeight,s-4)),c=d+2,l=Math.max(1,Math.floor((n-a)/2)+1),f=Math.max(1,Math.floor((s-c)/2)+1);t.moveTo(1,1).eraseDisplayBelow();let u="\u2500".repeat(a-2),p=kk(u,e.title);t.moveTo(l,f),t.dim.noFormat("\u250C"),xk(t,p),t.dim.noFormat("\u2510");for(let g=1;g<=d;g++)t.moveTo(l,f+g),t.dim.noFormat("\u2502"),t.moveTo(l+a-1,f+g),t.dim.noFormat("\u2502");return t.moveTo(l,f+c-1),t.dim.noFormat("\u2514"+"\u2500".repeat(a-2)+"\u2518"),{x:l,y:f,w:a,h:c,contentX:l+1,contentY:f+1,contentW:o,contentH:d}}function kk(t,e){if(!e)return{dashes:t};let n=` ${e} `;if(n.length+4>t.length)return{dashes:t};let s=2;return{dashes:t.slice(0,s)+" ".repeat(n.length)+t.slice(s+n.length),title:{offset:s,text:n}}}function xk(t,e){if(!e.title){t.dim.noFormat(e.dashes);return}t.dim.noFormat(e.dashes.slice(0,e.title.offset)),t.brightCyan.noFormat(e.title.text),t.dim.noFormat(e.dashes.slice(e.title.offset+e.title.text.length))}var ga=V(()=>{"use strict"});function Ak(t,e,n=yi){if(e.kind==="cancel")return{kind:"cancel"};if(e.kind==="back")return{kind:"back"};if(e.kind==="enter"){let s=n[t];return s?{kind:"resolve",action:s.key}:{kind:"back"}}if(e.kind==="up")return{kind:"continue",selected:Math.max(0,t-1)};if(e.kind==="down")return{kind:"continue",selected:Math.min(n.length-1,t+1)};if(e.kind==="char"){let s=e.ch.toLowerCase();if(s==="n")return{kind:"continue",selected:Math.min(n.length-1,t+1)};if(s==="p")return{kind:"continue",selected:Math.max(0,t-1)};let r=n.findIndex(i=>i.hotkey.toLowerCase()===s);if(r>=0){let i=n[r];if(i)return{kind:"resolve",action:i.key}}}return{kind:"continue",selected:t}}async function sh(t,e){Ir();let n=He(e.sessionId),s=e.importedFromMachine??"another machine",r=Be(e.cwd),i=yi.findIndex(a=>a.key==="view");i<0&&(i=0);let o=()=>{let d=7+yi.length*2+2,c=ys(t,{contentHeight:d,title:"Imported session"}),l=c.contentW,f=[{label:"session: ",value:n},{label:"from: ",value:s},{label:"cwd: ",value:r}],u=0;for(let p of f)t.moveTo(c.contentX,c.contentY+u),t.dim.noFormat(` ${p.label}`),t.noFormat(xc(p.value,l-p.label.length-2)),u++;u++,t.moveTo(c.contentX,c.contentY+u),t.noFormat(" What do you want to do?"),u+=2;for(let p=0;p<yi.length;p++){let g=yi[p];if(!g)continue;let w=` ${p===i?"\u276F":" "} ${g.label}`;t.moveTo(c.contentX,c.contentY+u),p===i?t.brightWhite.bgBlue.noFormat(ih(w,l)):t.noFormat(w),u++,t.moveTo(c.contentX,c.contentY+u),t.dim.noFormat(` ${g.description}`),u++}return u++,t.moveTo(c.contentX,c.contentY+u),t.dim.noFormat(" \u2191/\u2193 navigate \xB7 Enter select \xB7 f/v jump \xB7 Esc back"),c};return o(),t.hideCursor(),await new Promise(a=>{let d=!1,c=()=>{d||(d=!0,t.off("key",u),t.off("resize",f),t.grabInput(!1),t.hideCursor(!1),t.moveTo(1,1).eraseDisplayBelow())},l=p=>{c(),a(p)},f=()=>{d||o()},u=(p,g,h)=>{let w=Ck(p,h);if(!w)return;let v=Ak(i,w);if(v.kind==="cancel"){l("cancel");return}if(v.kind==="back"){l("back");return}if(v.kind==="resolve"){l(v.action);return}v.selected!==i&&(i=v.selected,o())};t.grabInput({}),t.on("key",u),t.on("resize",f)})}function Ck(t,e){return t==="UP"?{kind:"up"}:t==="DOWN"?{kind:"down"}:t==="ENTER"||t==="KP_ENTER"?{kind:"enter"}:t==="ESCAPE"?{kind:"back"}:t==="CTRL_C"||t==="CTRL_D"?{kind:"cancel"}:e?.isCharacter?{kind:"char",ch:t}:null}async function rh(t,e,n){let s=He(e.sessionId),r=e.title??Be(e.cwd),i=1,o=[{label:"Launch",hotkey:"l",description:"start a new agent session"},{label:"View transcript",hotkey:"v",description:"open read-only, no agent spawn"}],a=()=>{let d=ys(t,{contentHeight:11,title:"Open session"}),c=d.contentW,l=0;t.moveTo(d.contentX,d.contentY+l),t.dim.noFormat(" session: "),t.noFormat(xc(s,c-10)),l++,t.moveTo(d.contentX,d.contentY+l),t.noFormat(" "+xc(r,c-2)),l++,l++,t.moveTo(d.contentX,d.contentY+l),t.noFormat(" What do you want to do?"),l+=2;for(let f=0;f<o.length;f++){let u=o[f];if(!u)continue;let g=` ${f===i?"\u276F":" "} ${u.label}`;t.moveTo(d.contentX,d.contentY+l),f===i?t.brightWhite.bgBlue.noFormat(ih(g,c)):t.noFormat(g),l++,t.moveTo(d.contentX,d.contentY+l),t.dim.noFormat(` ${u.description}`),l++}l++,t.moveTo(d.contentX,d.contentY+l),t.dim.noFormat(" \u2191/\u2193 navigate \xB7 Enter select \xB7 l/v jump \xB7 Esc back")};return a(),t.hideCursor(),await new Promise(d=>{let c=!1,l=()=>{c=!0},f=p=>{l(),n.pop(),d(p)},u=(p,g,h)=>{if(p==="CTRL_C"||p==="CTRL_D"){f("cancel");return}if(p==="ESCAPE"){f("back");return}if(p==="ENTER"||p==="KP_ENTER"){f(i===0?"launch":"view");return}if(p==="UP"||p==="SHIFT_TAB"){i>0&&(i--,a());return}if(p==="DOWN"||p==="TAB"){i<o.length-1&&(i++,a());return}if(h?.isCharacter){let w=p.toLowerCase();if(w==="l"){f("launch");return}if(w==="v"){f("view");return}if(w==="n"){i<o.length-1&&(i++,a());return}if(w==="p"){i>0&&(i--,a());return}}};n.push({onKey:(p,g,h)=>{c||u(p,g,h)},onResize:()=>{c||a()}})})}function xc(t,e){return e<=1?"":t.length<=e?t:t.slice(0,Math.max(0,e-1))+"\u2026"}function ih(t,e){return t.length>=e?t.slice(0,e):t+" ".repeat(e-t.length)}var yi,Ac=V(()=>{"use strict";ue();Yt();ga();yi=[{key:"fork-local",label:"Fork locally",hotkey:"f",description:"spawn a local fork \u2014 original imported copy stays as-is"},{key:"view",label:"View transcript",hotkey:"v",description:"open read-only, no agent spawn"}]});function Ec(){return{filters:{cwdOnly:!1,hostFilter:"__local",includeNonInteractive:!1}}}async function Pc(t,e){process.stdout.write("\x1B[<u"),process.stdout.write("\x1B[?2004l"),process.stdout.write("\x1B[>4;0m"),process.stdout.write("\x1B[>5;0m"),process.stdout.write("\x1B[?1000l"),process.stdout.write("\x1B[?1002l"),process.stdout.write("\x1B[?1006l"),process.stdout.write("\x1B[?1l"),process.stdout.write("\x1B>");let n=e.prefs??Ec();e.prefs===void 0&&e.currentSessionId!==void 0&&e.sessions.find(M=>M.sessionId===e.currentSessionId)?.importedFromMachine&&(n.filters.hostFilter="__all");let s=Tc(e.sessions,e.cwd),r=k=>{let M=k;return n.filters.cwdOnly&&(M=M.filter(_=>_.cwd===e.cwd)),n.filters.includeNonInteractive||(M=M.filter(_=>_.interactive===!0)),M=Mk(M,n.filters.hostFilter),M},i=r(s),o={columns:e.config.tui.sessionColumns??cr,cwdMaxWidth:e.config.tui.cwdColumnMaxWidth},a=i.map(k=>ur(k,Date.now())),d=fr(a,o),c=1+i.length,l=0,f=0;if(e.currentSessionId!==void 0){let k=i.findIndex(M=>M.sessionId===e.currentSessionId);k>=0&&(l=k+1)}let u=!1,p="",g=120,h=!1,w=0,v="normal",b=null,x=!1,C="input",O=new un({history:[],collapsePastes:!1}),q=[],W=!1,Q=0,N=0,F=null,U=!1,J="",ie=null,be=!1,te=new un({history:[]});e.initialPrompt&&te.setBuffer(e.initialPrompt);let X=e.config.tui.promptHistoryMaxEntries;zr(P.globalTuiHistoryFile()).then(k=>{let M=k.length>X?k.slice(k.length-X):k;te.setHistory(M)}).catch(()=>{});let Ie=Rc(t),Y=ws(t),xe=0,vs="",Nt=0,Pt=[],lt=1,vt=0,Wn=0,Sr=0,we="",kr=[],zn=1,Is=0,Jn=[],Qe=1,mn=0,Ss=0,xr=0,Me=()=>{Ie=Rc(t),Y=ws(t);let k=Math.max(10,Y-Cc);Nt=Math.max(10,Y-oh);let M=Math.max(10,Y-8);vs=Pk(e.cwd,M);let _=te.state();Pt=pn(_.buffer,Nt);let K=qn(Pt,_,ya);lt=K.rendered,vt=K.windowStart,Wn=K.cursorVisualRow,Sr=K.cursorVisualCol;let ce=6+lt,ve=Math.max(3,Ie-ce);xe=Math.min(i.length,ve),we=Nn(lr,d,k,o).padEnd(k),kr=a.map(Ae=>Nn(Ae,d,k,o).padEnd(k))},Dt=()=>{a=i.map(k=>ur(k,Date.now())),d=fr(a,o),c=1+i.length,Me()},Oe=()=>{let k=r(s);u&&p.length>0?i=k.filter(M=>_k(M,p)):i=k,Dt(),u?(f=0,l=i.length>0?1:0):l>c-1&&(l=Math.max(0,c-1)),f+xe>i.length&&(f=Math.max(0,i.length-xe)),It()},hn=k=>{if(k!==void 0){let M=i.findIndex(_=>_.sessionId===k);if(M>=0){l=M+1,It();return}}l=i.length>0?1:0,f=0,It()},It=()=>{if(l===0)return;let k=l-1;k<f?f=k:k>=f+xe?f=k-xe+1:f+xe>i.length&&(f=Math.max(0,i.length-xe))},Kn=()=>Math.max(2,Y-2),Vn=()=>{let k=Kn(),M=`\u2500 ${vs} `,_=Math.max(1,k-M.length),K="\u2500".repeat(_);l===0?t.brightBlue.noFormat(`\u256D${M}${K}\u256E`):t.dim.noFormat(`\u256D${M}${K}\u256E`)},ks=()=>{let k=Kn(),M="\u2500".repeat(k);l===0?t.brightBlue.noFormat(`\u2570${M}\u256F`):t.dim.noFormat(`\u2570${M}\u256F`)},Yn=k=>{let M=Kn(),_=Pt[k],K="";_&&(K=(te.state().buffer[_.bufferIdx]??"").slice(_.startCol,_.endCol));let ce=Math.max(0,M-1-K.length),ve=" ".repeat(ce);l===0?(t.brightBlue.noFormat("\u2502"),t.noFormat(` ${K}${ve}`),t.brightBlue.noFormat("\u2502")):(t.dim.noFormat("\u2502"),t.noFormat(` ${K}${ve}`),t.dim.noFormat("\u2502"))},gn=k=>{let M=kr[k]??"",_=i[k],K=_&&_.priority&&_.priority>0?"* ":" ";l===k+1?t.brightWhite.bgBlue.noFormat(`${K}${M}`):t.noFormat(`${K}${M}`)},Qn=()=>{let k=f,M=Math.max(0,i.length-f-xe),_=[];return n.filters.cwdOnly&&_.push("cwd-only"),n.filters.hostFilter!=="__all"&&_.push(n.filters.hostFilter==="__local"?"host: local":`host: ${n.filters.hostFilter}`),n.filters.includeNonInteractive&&_.push("+non-interactive"),k>0&&_.push(`\u2191 ${k} above`),M>0&&_.push(`\u2193 ${M} below`),_.length===0?"":` ${_.join(" \xB7 ")}`},yn=k=>He(k),fe=()=>{Pe(()=>{if(t.moveTo(1,Ht()),v==="confirm-kill"&&b)t.brightYellow.noFormat(` kill ${yn(b.sessionId)}? [y/N]`);else if(v==="confirm-delete"&&b)b.status==="live"?t.brightRed.noFormat(` kill + delete ${yn(b.sessionId)}? [y/N]`):t.brightRed.noFormat(` delete ${yn(b.sessionId)}? [y/N]`);else if(v==="busy"&&b)t.dim.noFormat(` working on ${yn(b.sessionId)}\u2026`);else if(v==="rename"&&b)t.brightYellow.noFormat(` title: ${J}`),t.bgBrightYellow(" "),t.dim.noFormat(" Enter saves \xB7 Esc cancels");else if(ie!==null)t.dim.noFormat(` ${ie}`);else if(u){t.brightYellow.noFormat(` /${p}`),t.bgBrightYellow(" ");let k=i.length===0?" no matches":` ${i.length} match${i.length===1?"":"es"}`;t.dim.noFormat(`${k} \xB7 ^c clears`)}else t.dim.noFormat(Qn());t.styleReset(),t.eraseLineAfter()})},Zt=k=>zn+1+k,vi=()=>zn+lt+1,Ge=()=>zn+lt+3,St=k=>Ge()+1+(k-f),Ht=()=>Ge()+1+xe,ae=()=>{let k=Wn-vt;if(k<0||k>=lt)return;let M=3+Sr;t.moveTo(M,Zt(k))},We=()=>{Pe(()=>{t.hideCursor(),Me(),It(),zn=1,t.moveTo(1,1).eraseDisplayBelow(),Vn(),t(`
|
|
161
|
-
`);for(let k=0;k<lt;k++)
|
|
162
|
-
`);
|
|
177
|
+
`);if(s.filter(i=>i.length>0).length>1){this.onKey([{type:"paste",text:n.replace(/\r/g,"")}]);return}for(let i=0;i<s.length;i++)s[i].length>0&&this.handleRawStdin(Buffer.from(s[i],"binary")),i<s.length-1&&this.onKey([{type:"key",name:"ctrl-enter"}]);return}if(n.includes("\x1B[")&&/\x1b\[\d+(?:;\d+)?u/.test(n)){this.handleCsiUStdin(n);return}this.handleRawStdinSegment(n)}}handleCsi27Stdin(e){let n=/\x1b\[27;(\d+);(\d+)~/g,s=0,r;for(;(r=n.exec(e))!==null;){r.index>s&&this.handleRawStdin(Buffer.from(e.slice(s,r.index),"binary"));let i=parseInt(r[1],10),o=parseInt(r[2],10),a=Xm(o,i);a!==null?this.onKey([{type:"key",name:a}]):(i===1||i===2)&&o>=32&&o<127&&this.handleRawStdinSegment(String.fromCharCode(o)),s=r.index+r[0].length}s<e.length&&this.handleRawStdin(Buffer.from(e.slice(s),"binary"))}handleCsiUStdin(e){let n=/\x1b\[(\d+)(?:;(\d+))?u/g,s=0,r;for(;(r=n.exec(e))!==null;){r.index>s&&this.handleRawStdin(Buffer.from(e.slice(s,r.index),"binary"));let i=parseInt(r[1],10),o=r[2]!==void 0?parseInt(r[2],10):1,a=Xm(i,o);a!==null&&this.onKey([{type:"key",name:a}]),s=r.index+r[0].length}s<e.length&&this.handleRawStdin(Buffer.from(e.slice(s),"binary"))}handleRawStdinSegment(e){let n="\x1B[200~",s="\x1B[201~";for(;e.length>0;){if(this.pasteActive){let i=e.indexOf(s);if(i===-1){this.pasteBuffer+=e;return}this.pasteBuffer+=e.slice(0,i),e=e.slice(i+s.length),this.pasteActive=!1;let o=Buffer.from(this.pasteBuffer,"binary").toString("utf-8").replace(/\r\n?/g,`
|
|
178
|
+
`);this.pasteBuffer="";let a=Lm(o);a!==null?this.onKey([{type:"attachment-paths",paths:a}]):this.onKey([{type:"paste",text:o}]);continue}let r=e.indexOf(n);if(r===-1){let i=uk(e);i!==null?this.onKey([{type:"paste",text:i}]):this.terminalKitStdinHandler&&this.terminalKitStdinHandler(Buffer.from(e,"binary"));return}r>0&&this.terminalKitStdinHandler&&this.terminalKitStdinHandler(Buffer.from(e.slice(0,r),"binary")),e=e.slice(r+n.length),this.pasteActive=!0}}width(){return this.term.width||0}appendLines(e){e.length!==0&&(this.streamingActive=!1,this.lines.push(...e),this.trackLines(e),this.adjustScrollForRowChange(this.wrappedRowsOfMany(e)),this.moveStickyToEnd(),this.trimScrollback(),this.scheduleRepaint())}appendLine(e){this.streamingActive=!1,this.lines.push(e),this.trackLine(e),this.adjustScrollForRowChange(this.wrappedRowsOf(e)),this.moveStickyToEnd(),this.trimScrollback(),this.scheduleRepaint()}adjustScrollForRowChange(e){this.scrollOffset>0&&e!==0&&(this.scrollOffset=Math.max(0,this.scrollOffset+e))}wrappedRowsOf(e){let n=this.term.width;return this.wrapCacheWidth!==n&&(this.wrapCache.clear(),this.wrapCacheWidth=n),this.wrapOne(e,n).length}wrappedRowsOfMany(e){let n=0;for(let s of e)n+=this.wrappedRowsOf(s);return n}trackLine(e){this.lineIds.set(e,this.nextLineId++)}trackLines(e){for(let n of e)this.trackLine(n)}forgetLine(e){let n=this.lineIds.get(e);n!==void 0&&this.wrapCache.delete(n)}trimScrollback(){let e=this.lines.length-this.maxScrollbackLines;if(e<=0)return;let n=this.lines.splice(0,e);for(let s of n)this.forgetLine(s);this.invalidateSelectionIfTouches(n);for(let[s,r]of[...this.keyedBlocks.entries()])r.start-=e,r.start<0&&this.keyedBlocks.delete(s)}upsertLine(e,n){this.upsertLines(e,[n])}upsertLines(e,n){if(n.length===0)return;for(let o of n)o.blockKey=e;let s=this.keyedBlocks.get(e),r=!1,i=0;if(s){let o=s.start+s.count;r=o>=this.lines.length;let a=this.wrappedRowsOfMany(this.lines.slice(s.start,o)),d=n.length-s.count,c=this.lines.splice(s.start,s.count,...n);for(let l of c)this.forgetLine(l);if(this.trackLines(n),this.invalidateSelectionIfTouches(c),s.count=n.length,d!==0)for(let[l,f]of this.keyedBlocks)l!==e&&f.start>s.start&&(f.start+=d);i=this.wrappedRowsOfMany(n)-a}else r=!0,this.keyedBlocks.set(e,{start:this.lines.length,count:n.length}),this.lines.push(...n),this.trackLines(n),i=this.wrappedRowsOfMany(n);r&&(this.streamingActive=!1),this.adjustScrollForRowChange(i),e!==this.stickyBottomKey&&this.moveStickyToEnd(),this.trimScrollback(),this.scheduleRepaint()}appendStreaming(e,n,s,r){if(e.length===0)return;let i=e.split(`
|
|
179
|
+
`),[o,...a]=i,d=0;if(this.streamingActive&&this.lines.length>0){let l=this.lines[this.lines.length-1];if(l){let f=this.wrappedRowsOf(l);this.forgetLine(l),l.body+=o??"",d+=this.wrappedRowsOf(l)-f}}else{if(this.lines.length>0){let f=this.lines[this.lines.length-1];if(!(f&&f.body===""&&(!f.prefix||f.prefix===""))){let p={body:""};this.lines.push(p),this.trackLine(p),d+=this.wrappedRowsOf(p)}}let l={prefix:n,body:o??"",bodyStyle:s};r!==void 0&&(l.prefixStyle=r),this.lines.push(l),this.trackLine(l),d+=this.wrappedRowsOf(l)}let c=" ".repeat(n.length);for(let l of a){let f={prefix:c,body:l,bodyStyle:s};this.lines.push(f),this.trackLine(f),d+=this.wrappedRowsOf(f)}this.streamingActive=!0,this.adjustScrollForRowChange(d),this.moveStickyToEnd(),this.trimScrollback(),this.scheduleRepaint()}setSessionbar(e){this.sessionbar={...this.sessionbar,...e},this.syncWindowTitle(),this.repaint()}syncWindowTitle(){let e=this.sessionbar.title?.trim(),n=Gm(this.sessionbar.sessionId)||"hydra",s=e&&e.length>0?e:n,i=(this.readonly?`${s} [VIEW ONLY]`:s).replace(/[\x00-\x1f\x7f]/g,"").slice(0,200);i!==this.lastWindowTitle&&(this.lastWindowTitle=i,process.stdout.write(`\x1B]0;${i}\x1B\\`))}clearWindowTitle(){this.lastWindowTitle=null,process.stdout.write("\x1B]0;\x1B\\")}setBanner(e){this.banner={...this.banner,...e},this.writeProgressIndicator(this.banner.status==="busy"?3:0),this.syncedPartialRepaint(()=>this.drawBanner())}syncedPartialRepaint(e){this.started&&Pe(()=>{e(),this.placeCursor()})}currentModeId(){return this.banner.currentMode}writeProgressIndicator(e){this.started&&this.progressIndicatorEnabled&&e!==this.lastProgressState&&(this.lastProgressState=e,process.stdout.write(`\x1B]9;4;${e}\x1B\\`))}notify(e,n=4e3){this.bannerNotificationTimer&&clearTimeout(this.bannerNotificationTimer),this.bannerNotification=e,this.bannerNotificationTimer=setTimeout(()=>{this.bannerNotification=null,this.bannerNotificationTimer=null,this.syncedPartialRepaint(()=>this.drawBanner())},n),this.syncedPartialRepaint(()=>this.drawBanner())}setMouseEnabled(e){this.mouseEnabled!==e&&(this.mouseEnabled=e,this.started&&(e?(this.term.grabInput({mouse:"drag"}),this.term.on("mouse",this.mouseHandler)):(this.term.off("mouse",this.mouseHandler),this.term.grabInput(!0)),this.reclaimStdinAfterGrabInput()))}reclaimStdinAfterGrabInput(){if(this.terminalKitStdinHandler===null)return;let e=this.term;!e.stdin||typeof e.onStdin!="function"||(this.terminalKitStdinHandler=e.onStdin,e.stdin.removeListener("data",e.onStdin),e.stdin.removeListener("data",this.rawStdinHandler),e.stdin.on("data",this.rawStdinHandler))}isMouseEnabled(){return this.mouseEnabled}setInAppSelectionEnabled(e){this.inAppSelectionEnabled=e}isInAppSelectionEnabled(){return this.inAppSelectionEnabled}setSelection(e,n){let s=this.lineIndexById(e.sourceLineId),r=this.lineIndexById(n.sourceLineId),i=s<r||s===r&&e.offset<=n.offset,o=i?e:n,a=i?n:e;if(o.sourceLineId===a.sourceLineId&&o.offset===a.offset){this.clearSelection();return}let d={startLineId:o.sourceLineId,startOffset:o.offset,endLineId:a.sourceLineId,endOffset:a.offset},c=this.selection;c&&c.startLineId===d.startLineId&&c.startOffset===d.startOffset&&c.endLineId===d.endLineId&&c.endOffset===d.endOffset||(this.selection=d,this.repaint())}clearSelection(){this.selection!==null&&(this.selection=null,this.repaint())}hasSelection(){return this.selection!==null}getSelection(){return this.selection===null?null:{start:{sourceLineId:this.selection.startLineId,offset:this.selection.startOffset},end:{sourceLineId:this.selection.endLineId,offset:this.selection.endOffset}}}getSelectionText(){let e=this.selectionLineBounds();if(e===null)return"";let n=[];for(let s=e.loIdx;s<=e.hiIdx;s++){let r=this.lines[s];if(!r)continue;let i=this.lineIds.get(r),o=i===void 0?void 0:e.byId.get(i);if(!o)continue;let a=r.body??"",d;r.ansi?d=s===e.loIdx||s===e.hiIdx?"":a.replace(rk,""):(d=a.slice(o.start,o.end),ca(r.bodyStyle)&&(d=gk(d))),n.push(d)}return n.join(`
|
|
180
|
+
`)}selectionLineBounds(){let e=this.selection;if(e===null)return null;let n=this.lineIndexById(e.startLineId),s=this.lineIndexById(e.endLineId);if(n===-1||s===-1)return null;let r=n,i=s,o=e.startOffset,a=e.endOffset;n>s&&(r=s,i=n,o=e.endOffset,a=e.startOffset);let d=new Map;for(let c=r;c<=i;c++){let l=this.lines[c];if(!l)continue;let f=this.lineIds.get(l);if(f===void 0)continue;let u=(l.body??"").length,p=c===r?Math.max(0,Math.min(u,o)):0,g=c===i?Math.max(0,Math.min(u,a)):u;d.set(f,{start:p,end:g,toEnd:c<i})}return{loIdx:r,hiIdx:i,byId:d}}selectionRangeForChunk(e){if(this.selection===null||e.ansi)return null;let n=this.selectionRenderBounds??this.selectionLineBounds()?.byId??null;if(n===null)return null;let s=this.wrapOrigin.get(e);if(!s)return null;let r=n.get(s.sourceLineId);if(!r)return null;let i=s.sourceColOffset,o=i+e.body.length,a=Math.max(r.start,i),d=Math.min(r.end,o);return d<=a?null:{start:a-i,end:d-i,toEndOfLine:r.toEnd||r.end>o}}setBannerSearchIndicator(e){this.bannerSearchIndicator!==e&&(this.bannerSearchIndicator=e,this.syncedPartialRepaint(()=>this.drawBanner()))}bannerRightContent(){if(this.scrollbackSearch!==null){let e=this.scrollbackSearch,n=e.matches.length>0?` ${e.matchIndex+1}/${e.matches.length}`:e.term.length===0?"":" 0/0";return{text:`\u{1F50D} ${e.term}${n}`,kind:"search"}}return this.bannerSearchIndicator!==null?{text:`\u{1F50D} ${this.bannerSearchIndicator}`,kind:"search"}:this.bannerNotification!==null?{text:this.bannerNotification,kind:"notify"}:null}clearScrollback(){this.lines=[],this.keyedBlocks.clear(),this.wrapCache.clear(),this.wrapCacheWidth=0,this.streamingActive=!1,this.scrollOffset=0,this.selection!==null&&(this.selection=null),this.repaint()}invalidateSelectionIfTouches(e){if(this.selection!==null)for(let n of e){let s=this.lineIds.get(n);if(s!==void 0&&(s===this.selection.startLineId||s===this.selection.endLineId)){this.selection=null;return}}}setHideThoughts(e){this.hideThoughts!==e&&(this.hideThoughts=e,this.repaint())}clearKey(e){this.keyedBlocks.delete(e)}hasKey(e){return this.keyedBlocks.has(e)}removeKey(e){let n=this.keyedBlocks.get(e);if(!n)return;let s=n.start+n.count,r=s>=this.lines.length,i=this.wrappedRowsOfMany(this.lines.slice(n.start,s)),o=this.lines.splice(n.start,n.count);for(let a of o)this.forgetLine(a);this.invalidateSelectionIfTouches(o),this.keyedBlocks.delete(e);for(let[a,d]of this.keyedBlocks)a!==e&&d.start>n.start&&(d.start-=n.count);r&&(this.streamingActive=!1),this.adjustScrollForRowChange(-i),this.moveStickyToEnd(),this.scheduleRepaint()}setStickyBottomKey(e){this.stickyBottomKey=e,this.moveStickyToEnd(),this.scheduleRepaint()}moveStickyToEnd(){if(this.stickyBottomKey===null)return;let e=this.keyedBlocks.get(this.stickyBottomKey);if(!e)return;let n=e.start+e.count;if(n>=this.lines.length)return;let s=this.lines.splice(e.start,e.count);for(let[r,i]of this.keyedBlocks)r!==this.stickyBottomKey&&i.start>=n&&(i.start-=e.count);e.start=this.lines.length,this.lines.push(...s),this.streamingActive=!1}removeBlock(e){let n=this.keyedBlocks.get(e);if(!n)return;let s=n.start+n.count>=this.lines.length,r=this.wrappedRowsOfMany(this.lines.slice(n.start,n.start+n.count)),i=this.lines.splice(n.start,n.count);for(let o of i)this.forgetLine(o);this.invalidateSelectionIfTouches(i),this.keyedBlocks.delete(e);for(let[,o]of this.keyedBlocks)o.start>n.start&&(o.start-=n.count);s&&(this.streamingActive=!1),this.adjustScrollForRowChange(-r),this.scheduleRepaint()}contiguousRun(e,n){if(!this.keyedBlocks.has(e))return[];let s=[...n].map(d=>{let c=this.keyedBlocks.get(d);return c?{key:d,start:c.start,count:c.count}:null}).filter(d=>d!==null).sort((d,c)=>d.start-c.start),r=s.findIndex(d=>d.key===e);if(r<0)return[];let i=(d,c)=>{for(let[l,f]of this.keyedBlocks)if(!n.has(l)&&f.start>=d&&f.start<c)return!0;return!1},o=r;for(;o>0&&!i(s[o-1].start+s[o-1].count,s[o].start);)o--;let a=r;for(;a<s.length-1&&!i(s[a].start+s[a].count,s[a+1].start);)a++;return s.slice(o,a+1).map(d=>d.key)}setRunCollapsed(e,n,s){if(e.length===0)return;let r=e[0];if(!this.keyedBlocks.has(r))return;this.upsertLines(r,s);let i=this.keyedBlocks.get(r),o=i.start+i.count;for(let a of e){let d=this.keyedBlocks.get(a);d&&(o=Math.max(o,d.start+d.count))}for(let a=i.start+i.count;a<o;a++){let d=this.lines[a];d&&(d.collapsed=n)}this.scheduleRepaint()}redraw(){this.repaint()}fullRedraw(){this.lastFrameRows.clear(),this.lastFrameW=0,this.lastFrameH=0,this.lastWindowTitle=null,this.wrapCache.clear(),this.wrapCacheWidth=0,process.stdout.write("\x1B[?7l"),this.term.clear(),this.repaint()}pauseRepaint(){this.repaintPaused+=1}resumeRepaint(){this.repaintPaused!==0&&(this.repaintPaused-=1,this.repaintPaused===0&&this.repaintPending&&(this.repaintPending=!1,this.repaint()))}setQueuedPrompts(e){this.queuedTexts=[...e],this.lastQueueEditingIndex=this.dispatcher.state().queueIndex,this.repaint()}repaintNow(){this.repaint()}setPermissionPrompt(e){e!==null&&this.permissionPrompt===null&&this.clearSelection(),this.permissionPrompt=e?{...e}:null,this.repaint()}setOptionsPrompt(e){e!==null&&this.optionsPrompt===null&&this.clearSelection(),this.optionsPrompt=e?{...e,options:e.options.map(n=>({...n}))}:null,this.repaint()}isOptionsPromptActive(){return this.optionsPrompt!==null}setConfirmPrompt(e){e!==null&&this.confirmPrompt===null&&this.clearSelection(),this.confirmPrompt=e?{...e}:null,this.repaint()}setHelpPrompt(e){e!==null&&this.helpPrompt===null&&this.clearSelection(),this.helpPrompt=e?{...e,entries:[...e.entries]}:null,this.repaint()}isHelpPromptActive(){return this.helpPrompt!==null}setCompletions(e){e.length===this.completions.length&&e.every((s,r)=>{let i=this.completions[r];return i!==void 0&&i.name===s.name&&i.description===s.description})||(this.completions=[...e],this.repaint())}ensureSeparator(e){if(this.lines.length===0)return;let n=this.stickyBottomKey!==null?this.keyedBlocks.get(this.stickyBottomKey):void 0,s=n!==void 0&&n.start+n.count===this.lines.length,r=s?n.start-1:this.lines.length-1;if(r<0)return;let i=this.lines[r];if(i&&i.body===""&&(i.prefix===void 0||i.prefix===""))return;let o={body:""};e!==void 0&&(o.bodyStyle=e),s?(this.lines.splice(n.start,0,o),n.start+=1):this.lines.push(o),this.trackLine(o),this.streamingActive=!1,this.adjustScrollForRowChange(this.wrappedRowsOf(o)),this.trimScrollback(),this.scheduleRepaint()}refreshPrompt(){if(this.promptRows()!==this.lastPromptRows){this.repaint();return}this.syncedPartialRepaint(()=>{let e=this.dispatcher.state().queueIndex;e!==this.lastQueueEditingIndex&&(this.lastQueueEditingIndex=e,this.drawQueuedZone()),this.drawPrompt()})}handleKey(e,n){if(n.isCharacter){this.onKey([{type:"char",ch:e}]);return}if(e==="PAGE_UP"){this.scrollBy(this.scrollPageSize());return}if(e==="PAGE_DOWN"){this.scrollBy(-this.scrollPageSize());return}let s=ha(e);s&&this.onKey([{type:"key",name:s}])}handleMouse(e,n){if(e==="MOUSE_WHEEL_UP"){this.scrollBy(3);return}if(e==="MOUSE_WHEEL_DOWN"){this.scrollBy(-3);return}let s=this.mouseCell(n),r=fk(e),i=null;if(e==="MOUSE_DRAG"||e==="MOUSE_MOTION"?i="move":e.endsWith("_PRESSED")?i="press":e.endsWith("_RELEASED")&&(i="release"),i!==null&&s!==null&&this.onMouse&&this.onMouse({kind:i,button:r,x:s.x,y:s.y,name:e}),e==="MOUSE_LEFT_BUTTON_PRESSED"){this.pressCell=s,this.handleSelectionPress(s);return}if(e==="MOUSE_DRAG"&&s!==null){this.handleSelectionDrag(s);return}if(e==="MOUSE_LEFT_BUTTON_RELEASED"||e==="MOUSE_BUTTON_RELEASED"){let o=this.pressCell;this.pressCell=null;let a=this.inAppSelectionEnabled&&(this.selectionDragStarted||this.doubleClickPending);if(this.onBlockClick&&o!==null&&s!==null&&s.x===o.x&&s.y===o.y&&!a){let d=this.keyAtRow(s.y);d!==null&&this.onBlockClick(d)}this.handleSelectionRelease(s)}}handleSelectionPress(e){if(this.selectionAnchor=null,this.selectionDragStarted=!1,this.doubleClickPending=!1,!this.inAppSelectionEnabled||e===null)return;let n=this.resolveCellToSource(e.x,e.y);if(n===null){this.lastLeftClick=null;return}this.selectionAnchor=n;let s=Date.now(),r=this.lastLeftClick;if(r!==null&&s-r.t<=sk&&Math.abs(e.x-r.x)<=Km&&Math.abs(e.y-r.y)<=Km){let o=this.wordBoundsAt(n);o!==null&&(this.setSelection({sourceLineId:n.sourceLineId,offset:o.start},{sourceLineId:n.sourceLineId,offset:o.end}),this.doubleClickPending=!0),this.lastLeftClick=null}}handleSelectionDrag(e){if(!this.inAppSelectionEnabled||this.selectionAnchor===null||this.doubleClickPending)return;let n=this.resolveCellToSource(e.x,e.y);n!==null&&(this.selectionDragStarted=!0,this.setSelection(this.selectionAnchor,n))}handleSelectionRelease(e){let n=this.selectionDragStarted,s=this.doubleClickPending;if(this.selectionAnchor=null,this.selectionDragStarted=!1,this.doubleClickPending=!1,e!==null&&(this.lastLeftClick={x:e.x,y:e.y,t:Date.now()}),!!this.inAppSelectionEnabled){if(n||s){this.finalizeSelection();return}this.selection!==null&&this.clearSelection()}}wordBoundsAt(e){let n=this.lineById(e.sourceLineId);if(n===null||n.ansi)return null;let s=n.body??"";if(s.length===0)return null;let r=Math.max(0,Math.min(s.length-1,e.offset));if(e.offset>=s.length&&(r=s.length-1),!pc.test(s[r]))return null;let i=r;for(;i>0&&pc.test(s[i-1]);)i--;let o=r+1;for(;o<s.length&&pc.test(s[o]);)o++;return{start:i,end:o}}lineById(e){for(let n of this.lines)if(this.lineIds.get(n)===e)return n;return null}lineIndexById(e){for(let n=0;n<this.lines.length;n++){let s=this.lines[n];if(s&&this.lineIds.get(s)===e)return n}return-1}finalizeSelection(){let e=this.getSelectionText();e.length!==0&&Wm(e,{target:this.selectionClipboard}).then(n=>{if(n.ok){let s=e.length;this.notify(`copied ${s} char${s===1?"":"s"} to clipboard`)}else this.notify(`clipboard copy failed: ${n.reason}`)},n=>{this.notify(`clipboard copy failed: ${n.message}`)})}mouseCell(e){if(!e||typeof e!="object")return null;let n=e,s=Number(n.x),r=Number(n.y);return!Number.isFinite(s)||!Number.isFinite(r)?null:{x:s,y:r}}keyAtRow(e){let n=this.term.width,s=1,r=this.scrollbackVisibleRows();if(r<=0)return null;let i=e-s;if(i<0||i>=r)return null;let{rows:o}=this.wrapTail(n,r+this.scrollOffset),a=o.length-this.scrollOffset,d=Math.max(0,a-r),c=o.slice(d,a),l=Math.max(0,r-c.length),f=i-l;return f<0||f>=c.length?null:c[f]?.blockKey??null}resolveCellToSource(e,n){if(!Number.isFinite(e)||!Number.isFinite(n))return null;let s=this.term.width,r=1,i=this.scrollbackVisibleRows();if(i<=0)return null;let o=n-r;if(o<0||o>=i||e<1||e>s)return null;let{rows:a}=this.wrapTail(s,i+this.scrollOffset),d=a.length-this.scrollOffset,c=Math.max(0,d-i),l=a.slice(c,d),f=Math.max(0,i-l.length),u=o-f;if(u<0||u>=l.length)return null;let p=l[u];if(!p)return null;let g=this.wrapOrigin.get(p);if(!g)return null;let h=qn(p.prefix??""),w=e-1-h;if(w<0)return{sourceLineId:g.sourceLineId,offset:g.sourceColOffset};let v=ca(p.bodyStyle)?Nm(vc(p.body),w):Bm(p.body,w);return{sourceLineId:g.sourceLineId,offset:g.sourceColOffset+v}}scrollBy(e){if(e===0)return;this.scrollbackSearch!==null&&this.acceptScrollbackSearch();let n=this.maxScrollOffset(),s=Math.min(n,Math.max(0,this.scrollOffset+e));s!==this.scrollOffset&&(this.scrollOffset=s,this.repaint())}scrollToBottom(){this.scrollbackSearch!==null&&this.acceptScrollbackSearch(),this.scrollOffset!==0&&(this.scrollOffset=0,this.repaint())}scrollToTop(){this.scrollbackSearch!==null&&this.acceptScrollbackSearch();let e=this.maxScrollOffset();this.scrollOffset!==e&&(this.scrollOffset=e,this.repaint())}isScrolledBack(){return this.scrollOffset>0}isScrollbackSearchActive(){return this.scrollbackSearch!==null}enterScrollbackSearch(){this.scrollbackSearch===null&&(this.scrollbackSearch={term:"",matchIndex:0,matches:[],baselineScroll:this.scrollOffset},this.scrollbackHighlight=null,this.repaint())}updateScrollbackSearchTerm(e){if(this.scrollbackSearch===null)return;let n=e.toLowerCase(),s=[];if(n.length>0)for(let r=this.lines.length-1;r>=0;r--){let i=this.lines[r];if(!i||i.body.length===0||i.ansi)continue;let o=i.body.toLowerCase(),a=[],d=0;for(;d<o.length;){let c=o.indexOf(n,d);if(c===-1)break;a.push(c),d=c+n.length}for(let c=a.length-1;c>=0;c--)s.push({lineIdx:r,col:a[c]})}this.scrollbackSearch.term=e,this.scrollbackSearch.matches=s,this.scrollbackSearch.matchIndex=0,this.scrollbackHighlight=n.length>0?n:null,s.length>0&&this.scrollToMatch(s[0]),this.repaint()}advanceScrollbackSearch(){if(this.scrollbackSearch===null||this.scrollbackSearch.matches.length===0)return;let e=Math.min(this.scrollbackSearch.matches.length-1,this.scrollbackSearch.matchIndex+1);e!==this.scrollbackSearch.matchIndex&&(this.scrollbackSearch.matchIndex=e,this.scrollToMatch(this.scrollbackSearch.matches[e]),this.repaint())}retreatScrollbackSearch(){this.scrollbackSearch===null||this.scrollbackSearch.matches.length===0||this.scrollbackSearch.matchIndex!==0&&(this.scrollbackSearch.matchIndex-=1,this.scrollToMatch(this.scrollbackSearch.matches[this.scrollbackSearch.matchIndex]),this.repaint())}acceptScrollbackSearch(){this.scrollbackSearch!==null&&(this.scrollbackSearch=null,this.scrollbackHighlight=null,this.repaint())}cancelScrollbackSearch(){if(this.scrollbackSearch===null)return;let e=this.scrollbackSearch.baselineScroll;this.scrollbackSearch=null,this.scrollbackHighlight=null,this.scrollOffset=e,this.repaint()}scrollbackSearchTerm(){return this.scrollbackSearch?.term??""}currentMatchInfo(){if(this.scrollbackSearch===null||this.scrollbackSearch.matches.length===0)return null;let e=this.scrollbackSearch.matches[this.scrollbackSearch.matchIndex];if(!e)return null;let n=this.lines[e.lineIdx];if(!n)return null;let s=this.lineIds.get(n);return s===void 0?null:{lineId:s,col:e.col,length:this.scrollbackSearch.term.length}}activeMatchCol(e,n){if(!e||n===null)return null;let s=this.wrapOrigin.get(e);if(!s||s.sourceLineId!==n.lineId)return null;let r=n.col-s.sourceColOffset;return r<0||r>=e.body.length?null:r}scrollToMatch(e){let n=this.term.width,s=this.scrollbackVisibleRows();if(s<=0)return;let r=0;for(let l=this.lines.length-1;l>e.lineIdx;l--){let f=this.lines[l];f&&(r+=this.wrapOne(f,n).length)}let i=this.lines[e.lineIdx],o=0;if(i){let l=this.wrapOne(i,n),f=0;for(let u=0;u<l.length;u++){let p=l[u];if(!p)continue;let g=p.body.length;if(e.col<f+g){o=l.length-1-u;break}f+=g}}let a=r+o,d=Math.max(0,a-Math.floor(s/2)),c=this.maxScrollOffset();this.scrollOffset=Math.min(c,d)}scrollPageSize(){return Math.max(1,this.scrollbackVisibleRows()-2)}scrollbackVisibleRows(){let n=this.term.height-this.promptRows()-je-qe-Ye-qe-this.chipRows()-this.queuedRows()-this.completionRows();return Math.max(0,n-1+1)}maxScrollOffset(){let{rows:e}=this.wrapTail(this.term.width,Number.POSITIVE_INFINITY);return Math.max(0,e.length-this.scrollbackVisibleRows())}scheduleRepaint(){if(!this.started)return;if(this.repaintPaused>0){this.repaintPending=!0;return}if(this.contentRepaintThrottleMs<=0){this.repaint();return}let n=Date.now()-this.lastRepaintAt;if(n>=this.contentRepaintThrottleMs){this.throttledRepaintTimer&&(clearTimeout(this.throttledRepaintTimer),this.throttledRepaintTimer=null),this.repaint();return}this.throttledRepaintTimer===null&&(this.throttledRepaintTimer=setTimeout(()=>{this.throttledRepaintTimer=null,this.repaint()},this.contentRepaintThrottleMs-n))}paintRow(e,n,s){this.started&&(e<1||e>this.term.height||this.lastFrameRows.get(e)!==n&&(this.lastFrameRows.set(e,n),this.term.moveTo(1,e),s(),this.term.styleReset(),this.term.eraseLineAfter()))}repaint(){if(!this.started)return;if(this.repaintPaused>0){this.repaintPending=!0;return}this.lastRepaintAt=Date.now(),this.throttledRepaintTimer&&(clearTimeout(this.throttledRepaintTimer),this.throttledRepaintTimer=null);let e=this.term.width,n=this.term.height;e<20||n<8||((e!==this.lastFrameW||n!==this.lastFrameH)&&(this.lastFrameRows.clear(),this.lastFrameW=e,this.lastFrameH=n),Pe(()=>{this.term.hideCursor(),this.drawScrollback(),this.drawCompletionZone(),this.drawQueuedZone(),this.drawAttachmentChipZone();let s=this.promptRows(),r=n-s-Ye-qe-je;this.drawSeparator(r),this.drawPrompt(),this.drawBanner(),this.drawSeparator(n-je),this.drawSessionbar(),this.placeCursor(),(this.permissionPrompt||this.optionsPrompt||this.confirmPrompt||this.helpPrompt)&&this.term.hideCursor(!1),this.lastPromptRows=s}))}drawSessionbar(){let e=this.term.width,n=this.term.height,s=Gm(this.sessionbar.sessionId),r=this.sessionbar.title?.trim(),i=fp(this.sessionbar.agent,this.sessionbar.model),o=Be(this.sessionbar.cwd),a=kk(this.sessionbar.usage),d=`sbar|${e}|${s}|${i}|${o}|${r??""}|${a??""}`;this.paintRow(n,d,()=>{let c=a?a.length+3:0,l=s.length+3+i.length+3+(r?3:0)+c,f=Math.max(8,e-l),u,p;if(r){let g=Math.min(r.length,8);u=Math.min(o.length,Math.max(8,f-g)),p=Math.max(0,f-u)}else p=0,u=f;if(this.term.yellow(s)(" \xB7 ").cyan.noFormat(i)(" \xB7 ").dim.noFormat(ot(o,u)),r&&this.term(" \xB7 ").bold.noFormat(ot(r,p)),this.term.eraseLineAfter(),a){let g=fa(a),h=Math.max(1,e-g);this.term.moveTo(h,n).eraseLineAfter(),this.term.dim.noFormat(a)}})}drawSeparator(e){let n=this.term.width;this.paintRow(e,`sep|${n}`,()=>{this.term.dim("\u2500".repeat(n))})}drawScrollback(){let e=this.term.width,n=1,s=this.scrollbackVisibleRows();if(s<=0)return;let{rows:r,exhausted:i}=this.wrapTail(e,s+this.scrollOffset);if(i){let u=Math.max(0,r.length-s);this.scrollOffset>u&&(this.scrollOffset=u)}let o=r.length-this.scrollOffset,a=Math.max(0,o-s),d=r.slice(a,o),c=Math.max(0,s-d.length),l=this.currentMatchInfo(),f=l?.length??0;this.selectionRenderBounds=this.selectionLineBounds()?.byId??null;for(let u=0;u<s;u++){let p=n+u,g=u-c,h=g>=0?d[g]:void 0,w=this.activeMatchCol(h,l),v=h?this.selectionRangeForChunk(h):null,b=pk("sb",e,h,this.scrollbackHighlight,w,v);this.paintRow(p,b,()=>{h&&this.writeFormattedLine(h,e,w,f,v)})}if(this.onBlockVisible&&this.pendingVisibleKeys.size>0){let u=new Set;for(let g of d)g.blockKey!==void 0&&u.add(g.blockKey);let p=[];for(let g of this.pendingVisibleKeys)u.has(g)&&p.push(g);for(let g of p)this.pendingVisibleKeys.delete(g),this.onBlockVisible(g)}}notifyWhenVisible(e){this.onBlockVisible&&(this.pendingVisibleKeys.add(e),this.scheduleRepaint())}queuedRows(){return Math.min(hc,this.queuedTexts.length)}chipRows(){return Math.min(yc,this.attachments.length)}setAttachments(e){this.attachments.length===e.length&&this.attachments.every((n,s)=>n===e[s])||(this.attachments=[...e],this.repaint())}completionRows(){return this.permissionPrompt||this.optionsPrompt||this.confirmPrompt||this.helpPrompt?0:Math.min(gc,this.completions.length)}drawCompletionZone(){let e=this.completionRows();if(e===0)return;let n=this.term.width,s=this.promptRows(),r=this.term.height-s-je-qe-Ye,i=this.queuedRows(),o=this.chipRows(),d=r-1-i-o-e+1,c=0;for(let l of this.completions.slice(0,e))l.name.length>c&&(c=l.name.length);for(let l=0;l<e;l++){let f=d+l,u=this.completions[l],p=l===e-1&&this.completions.length>gc,g=this.completions.length-gc+1,h=u?p?`comp|${n}|overflow|${g}`:`comp|${n}|${c}|${u.name}|${u.description??""}`:`comp|${n}|empty`;this.paintRow(f,h,()=>{if(!u)return;if(p){this.term.dim(` + ${g} more match(es)`);return}let w=u.name.padEnd(c),v=u.description??"",b=n-w.length-4,x=b>0?ot(v,b):"";this.term(" ").brightCyan(w),x.length>0&&this.term(" ").dim(x)})}}drawAttachmentChipZone(){let e=this.chipRows();if(e===0)return;let n=this.term.width,s=this.promptRows(),o=this.term.height-s-je-qe-Ye-1-e+1,a=this.isIterm2();for(let d=0;d<e;d++){let c=o+d,l=d===e-1&&this.attachments.length>yc,f=this.attachments.length-yc,u=this.attachments[d],p=u?`${u.name??"image"} \xB7 ${Et(u.sizeBytes)}`:"",g=l?`chip|${n}|overflow|${f}`:u?`chip|${n}|${a?"i":"t"}|${p}|${u.sizeBytes}`:`chip|${n}|empty`;this.paintRow(c,g,()=>{if(l){this.term.dim(` \u{1F4CE} + ${f+1} more attached`);return}u&&(this.term(" ").yellow(`\u{1F4CE} ${p}`),a&&(this.term(" "),this.writeIterm2Image(u.data,1)))})}}isIterm2(){let e=process.env;return e.LC_TERMINAL==="iTerm2"||e.TERM_PROGRAM==="iTerm.app"}writeIterm2Image(e,n){process.stdout.write(yk(e,n,!!process.env.TMUX))}drawQueuedZone(){let e=this.queuedRows();if(e===0)return;let n=this.term.width,s=this.promptRows(),r=this.term.height-s-je-qe-Ye,i=this.chipRows(),a=r-1-i-e+1,d=this.dispatcher.state().queueIndex;for(let c=0;c<e;c++){let l=a+c,f=this.queuedTexts[c],u=c===e-1&&this.queuedTexts.length>hc,p=this.queuedTexts.length-hc,g=f===void 0?"":u?`+ ${p+1} more queued`:ot(Sk(f),n-4),h=!u&&c===d,w=f===void 0?`queued|${n}|empty`:`queued|${n}|${h?"edit":u?"ovf":"row"}|${g}`;this.paintRow(l,w,()=>{if(f===void 0)return;let v=`\u23F3 ${g}`,b=v+" ".repeat(Math.max(0,n-1-v.length));h?this.term.bgBlue.brightYellow("\u25B8"):this.term.bgBlue(" "),this.term.bgBlue.brightWhite.noFormat(b)})}}drawPrompt(){if(this.permissionPrompt){this.drawPermissionPrompt();return}if(this.optionsPrompt){this.drawOptionsPrompt();return}if(this.confirmPrompt){this.drawConfirmPrompt();return}if(this.helpPrompt){this.drawHelpPrompt();return}if(this.readonly)return;let e=this.term.width,n=Math.max(1,e-2),s=this.dispatcher.state(),r=pn(s.buffer,n),i=Wn(r,s,mc),o=this.term.height-i.rendered-Ye-qe-je+1;for(let a=0;a<i.rendered;a++){let d=r[i.windowStart+a],c=o+a,l="wrap",f="";d&&(d.bufferIdx===0&&d.startCol===0?l="first":d.startCol===0&&(l="newline"),f=(s.buffer[d.bufferIdx]??"").slice(d.startCol,d.endCol));let u=d?`prompt|${this.term.width}|${l}|${f}`:`prompt|${this.term.width}|empty`;this.paintRow(c,u,()=>{d&&(l==="first"?this.term.brightWhite("> "):l==="newline"?this.term.dim("\xB7 "):this.term(" "),this.term.noFormat(f))})}}drawConfirmPrompt(){let e=this.confirmPrompt;if(!e)return;let n=this.term.width,s=this.term.height-wc-Ye-qe-je+1;this.paintRow(s,`confirm|q|${n}|${e.question}`,()=>{this.term.brightYellow(` ? ${ot(e.question,n-4)}`)}),this.paintRow(s+1,`confirm|h|${n}|${e.hint}`,()=>{this.term.dim(` ${ot(e.hint,n-2)}`)})}drawHelpPrompt(){let e=this.helpPrompt;if(!e)return;let n=this.term.width,s=this.helpRows(),r=this.term.height-s-Ye-qe-je+1,i=r,o=(d,c)=>{i>=r+s||(this.paintRow(i,d,c),i+=1)};o(`help|t|${n}|${e.title}`,()=>{this.term.brightYellow(` \u2753 ${ot(e.title,n-5)}`)});let a=Math.min(24,Math.max(...e.entries.map(d=>d===null?0:d[0].length),4));for(let d of e.entries){if(i>=r+s-1)break;if(d===null){o(`help|sep|${n}|${i}`,()=>{});continue}let[c,l]=d,f=c.padEnd(a);o(`help|e|${n}|${c}|${l}`,()=>{this.term(" "),this.term.brightCyan.noFormat(f),this.term.noFormat(` ${ot(l,n-2-a-1)}`)})}o(`help|hint|${n}|${e.hint}`,()=>{this.term.dim(` ${ot(e.hint,n-2)}`)})}helpRows(){return this.helpPrompt?Math.min(ak,2+this.helpPrompt.entries.length):0}drawPermissionPrompt(){let e=this.permissionPrompt;if(!e)return;let n=this.term.width,s=this.permissionRows(),r=this.term.height-s-Ye-qe-je+1,i=r,o=(d,c)=>{i>=r+s||(this.paintRow(i,d,c),i+=1)};o(`perm|t|${n}|${e.title}`,()=>{this.term.brightYellow(` \u{1F512} ${ot(e.title,n-5)}`)});let a=e.detail&&e.detail.length>0?e.detail:"This action requires approval";o(`perm|sub|${n}|${a}`,()=>{this.term.dim(` ${ot(a,n-2)}`)}),o(`perm|q|${n}`,()=>{this.term(" Do you want to proceed?")});for(let d=0;d<e.options.length&&!(i>=r+s-1);d++){let c=e.options[d];if(!c)continue;let l=d===e.selectedIndex,u=` ${l?"\u276F":" "} ${d+1}. ${ot(c.label,n-8)}`;o(`perm|o|${n}|${d}|${l?"1":"0"}|${c.label}`,()=>{l?this.term.brightYellow(u):this.term.dim(u)})}o(`perm|hint|${n}`,()=>{this.term.dim(" \u2191/\u2193 choose \xB7 Enter submit \xB7 Esc cancel \xB7 1\u20139 quick-pick")})}drawBanner(){let e=this.term.height-je-qe,n=this.term.width,s=this.banner.status==="busy"&&this.banner.elapsedMs!==void 0&&this.banner.elapsedMs>=1e3?Gt(this.banner.elapsedMs):"",r=this.bannerRightContent(),i=r?`${r.kind}|${r.text}`:"",o=this.banner.status==="busy"&&this.banner.stalled===!0,a=`bnr|${n}|${this.banner.status}|${s}|${o?"1":"0"}|${this.banner.queued}|${this.scrollOffset}|${this.banner.currentMode??""}|${this.banner.hint}|`+i;this.paintRow(e,a,()=>{let d=this.banner.status==="busy"?"\u25CF":"\u25CB";this.banner.status==="busy"?(o?this.term.brightRed(`${d} stalled`):this.term.brightYellow(`${d} ${this.banner.status}`),s&&this.term(" ").dim(s)):this.banner.status==="disconnected"?this.term.brightRed(`${d} ${this.banner.status}`):this.banner.status==="cold"?this.term.brightMagenta(`${d} ${this.banner.status}`):this.term.brightGreen(`${d} ${this.banner.status}`),this.banner.queued>0&&this.term(" \xB7 ").brightYellow(`${this.banner.queued} queued`),this.scrollOffset>0&&this.term(" \xB7 ").brightCyan(`\u2191 ${this.scrollOffset}`);let c=this.banner.currentMode?this.banner.hint.replace("\u21E7\u21E5 mode",`\u21E7\u21E5 mode: ${this.banner.currentMode}`):this.banner.hint;if(this.term(" \xB7 ").dim(c),this.term.eraseLineAfter(),r){let l=fa(r.text),f=Math.max(1,n-l);this.term.moveTo(f,e).eraseLineAfter(),r.kind==="search"?this.term.brightCyan.noFormat(r.text):this.term.brightYellow.noFormat(r.text)}})}placeCursor(){if(!this.started)return;if(this.permissionPrompt){let l=this.permissionRows(),u=this.term.height-l-Ye-qe-je+1+3+this.permissionPrompt.selectedIndex,p=this.term.height-Ye-qe-je;this.term.moveTo(2,Math.min(u,p));return}if(this.optionsPrompt){let l=this.optionsRows(),u=this.term.height-l-Ye-qe-je+1+1+this.optionsPrompt.selectedIndex,p=this.term.height-Ye-qe-je;this.term.moveTo(2,Math.min(u,p));return}if(this.confirmPrompt){let l=this.term.height-wc-Ye-qe-je+1;this.term.moveTo(2,l);return}if(this.helpPrompt){let l=this.helpRows(),f=this.term.height-l-Ye-qe-je+1;this.term.moveTo(2,f);return}if(this.scrollbackSearch){this.term.hideCursor(!0);return}if(this.readonly){this.term.hideCursor(!0);return}this.term.hideCursor(!1);let e=this.term.width,n=Math.max(1,e-2),s=this.dispatcher.state(),r=pn(s.buffer,n),i=Wn(r,s,mc),a=this.term.height-i.rendered-Ye-qe-je+1+Math.max(0,i.cursorVisualRow-i.windowStart),d=i.cursorVisualCol+3,c=this.term.height-Ye-qe-je;this.term.moveTo(Math.min(d,this.term.width),Math.min(a,c))}promptRows(){if(this.permissionPrompt)return this.permissionRows();if(this.optionsPrompt)return this.optionsRows();if(this.confirmPrompt)return wc;if(this.helpPrompt)return this.helpRows();if(this.readonly)return 0;let e=this.term.width,n=Math.max(1,e-2),s=this.dispatcher.state(),r=pn(s.buffer,n);return Math.min(mc,Math.max(1,r.length))}permissionRows(){return this.permissionPrompt?Math.min(ik,4+this.permissionPrompt.options.length):0}optionsRows(){return this.optionsPrompt?Math.min(ok,2+this.optionsPrompt.options.length):0}drawOptionsPrompt(){let e=this.optionsPrompt;if(!e)return;let n=this.term.width,s=this.optionsRows(),r=this.term.height-s-Ye-qe-je+1,i=r,o=(d,c)=>{i>=r+s||(this.paintRow(i,d,c),i+=1)};o(`opts|t|${n}|${e.title}`,()=>{this.term.brightYellow(` \u2699 ${ot(e.title,n-5)}`)});let a=Math.max(...e.options.map(d=>d.label.length),0);for(let d=0;d<e.options.length&&!(i>=r+s-1);d++){let c=e.options[d];if(!c)continue;let l=d===e.selectedIndex,u=` ${l?"\u276F":" "} ${d+1}. `,p=c.label.padEnd(a),g=n-u.length-3,h=`${u}${ot(`${p} ${c.value}`,g)}`;o(`opts|o|${n}|${d}|${l?"1":"0"}|${c.value}|${c.label}`,()=>{l?this.term.brightYellow(h):this.term.dim(h)})}o(`opts|hint|${n}`,()=>{this.term.dim(" \u2191/\u2193 choose \xB7 Enter this session \xB7 s save default \xB7 Esc close")})}wrapTail(e,n){let s=c=>c.collapsed===!0||this.hideThoughts&&c.bodyStyle==="thought";if(e<=4){let c=[];for(let f of this.lines)s(f)||c.push(f);let l=Math.min(n,c.length);return{rows:c.slice(c.length-l),exhausted:n>=c.length}}if(this.wrapCacheWidth!==e&&(this.wrapCache.clear(),this.wrapCacheWidth=e),n<=0||this.lines.length===0)return{rows:[],exhausted:!0};let r=[],i=0,o=0,a=!1;for(let c=this.lines.length-1;c>=0;c--){let l=this.lines[c];if(s(l)){c===0&&(a=!0);continue}let f=this.wrapOne(l,e);if(r.push(f),i+=f.length,o=c,i>=n)break}let d=[];for(let c=r.length-1;c>=0;c--)d.push(...r[c]);return{rows:d,exhausted:o===0||a}}wrapOne(e,n){let s=this.lineIds.get(e);if(s!==void 0){let f=this.wrapCache.get(s);if(f)return f}let r=e.prefix??"",i=qn(r),o=Math.max(1,n-i),a=ca(e.bodyStyle),d=e.ansi?mk(e.body,o):wk(e.body,o,{stripMarkup:a}),c=[],l=0;for(let f=0;f<d.length;f++){let u=d[f]??"",p={prefix:f===0?e.prefix:" ".repeat(i),body:u};if(e.prefixStyle!==void 0&&(p.prefixStyle=e.prefixStyle),e.bodyStyle!==void 0&&(p.bodyStyle=e.bodyStyle),e.blockKey!==void 0&&(p.blockKey=e.blockKey),e.fillRow&&(p.fillRow=!0),e.ansi&&(p.ansi=!0),f===0&&e.iterm2Image&&(p.iterm2Image=e.iterm2Image),s!==void 0&&u.length>0){let g=e.body.indexOf(u,l),h=g===-1?l:g;this.wrapOrigin.set(p,{sourceLineId:s,sourceColOffset:h}),l=h+u.length}c.push(p)}return s!==void 0&&this.wrapCache.set(s,c),c}writeFormattedLine(e,n,s=null,r=0,i=null){e.prefix&&fn(this.term,e.prefix,e.prefixStyle??e.bodyStyle);let o=Math.max(0,n-qn(e.prefix??"")),a=ca(e.bodyStyle),d=e.ansi?e.body:ot(e.body,o,{stripMarkup:a}),c=(l,f)=>{if(l.length!==0)if(this.scrollbackHighlight!==null&&!e.ansi){let u=s!==null&&s>=f?s-f:null;Vm(this.term,l,e.bodyStyle,this.scrollbackHighlight,u,r)}else fn(this.term,l,e.bodyStyle)};if(i!==null&&!e.ansi){let l=Math.max(0,Math.min(d.length,i.start)),f=Math.max(l,Math.min(d.length,i.end));c(d.slice(0,l),0),f>l&&fn(this.term,d.slice(l,f),"selection-highlight"),c(d.slice(f),f)}else this.scrollbackHighlight!==null&&!e.ansi?Vm(this.term,d,e.bodyStyle,this.scrollbackHighlight,s,r):fn(this.term,d,e.bodyStyle);if(e.fillRow){let l=e.ansi?fa(d):qn(d),f=o-l;if(f>0){let u=i!==null&&i.toEndOfLine?"selection-highlight":e.bodyStyle;fn(this.term," ".repeat(f),u)}}(e.ansi||e.body.includes("^"))&&this.term.styleReset(),e.iterm2Image&&this.isIterm2()&&this.writeIterm2Image(e.iterm2Image.data,e.iterm2Image.heightCells)}};Zm=/[^\x20-\x7e]/,bc=new Intl.Segmenter(void 0,{granularity:"grapheme"}),eh=!1;hk=/[a-zA-Z+\-:_!#/]/;Gm=He});function Ir(){process.stdout.write("\x1B[<u"),process.stdout.write("\x1B[?2004l"),process.stdout.write("\x1B[>4;0m"),process.stdout.write("\x1B[>5;0m"),process.stdout.write("\x1B[?1000l"),process.stdout.write("\x1B[?1002l"),process.stdout.write("\x1B[?1006l"),process.stdout.write("\x1B[?1l"),process.stdout.write("\x1B>")}function Sc(t){return t.width??80}function kc(t){return t.height??24}function ws(t,e){let n=Sc(t),s=kc(t),r=e.contentWidth??64,i=Math.max(10,n-4),o=Math.min(r,i),a=o+2,d=Math.max(1,Math.min(e.contentHeight,s-4)),c=d+2,l=Math.max(1,Math.floor((n-a)/2)+1),f=Math.max(1,Math.floor((s-c)/2)+1);t.moveTo(1,1).eraseDisplayBelow();let u="\u2500".repeat(a-2),p=xk(u,e.title);t.moveTo(l,f),t.dim.noFormat("\u250C"),Ak(t,p),t.dim.noFormat("\u2510");for(let g=1;g<=d;g++)t.moveTo(l,f+g),t.dim.noFormat("\u2502"),t.moveTo(l+a-1,f+g),t.dim.noFormat("\u2502");return t.moveTo(l,f+c-1),t.dim.noFormat("\u2514"+"\u2500".repeat(a-2)+"\u2518"),{x:l,y:f,w:a,h:c,contentX:l+1,contentY:f+1,contentW:o,contentH:d}}function xk(t,e){if(!e)return{dashes:t};let n=` ${e} `;if(n.length+4>t.length)return{dashes:t};let s=2;return{dashes:t.slice(0,s)+" ".repeat(n.length)+t.slice(s+n.length),title:{offset:s,text:n}}}function Ak(t,e){if(!e.title){t.dim.noFormat(e.dashes);return}t.dim.noFormat(e.dashes.slice(0,e.title.offset)),t.brightCyan.noFormat(e.title.text),t.dim.noFormat(e.dashes.slice(e.title.offset+e.title.text.length))}var ga=V(()=>{"use strict"});function Ck(t,e,n=yi){if(e.kind==="cancel")return{kind:"cancel"};if(e.kind==="back")return{kind:"back"};if(e.kind==="enter"){let s=n[t];return s?{kind:"resolve",action:s.key}:{kind:"back"}}if(e.kind==="up")return{kind:"continue",selected:Math.max(0,t-1)};if(e.kind==="down")return{kind:"continue",selected:Math.min(n.length-1,t+1)};if(e.kind==="char"){let s=e.ch.toLowerCase();if(s==="n")return{kind:"continue",selected:Math.min(n.length-1,t+1)};if(s==="p")return{kind:"continue",selected:Math.max(0,t-1)};let r=n.findIndex(i=>i.hotkey.toLowerCase()===s);if(r>=0){let i=n[r];if(i)return{kind:"resolve",action:i.key}}}return{kind:"continue",selected:t}}async function rh(t,e){Ir();let n=He(e.sessionId),s=e.importedFromMachine??"another machine",r=Be(e.cwd),i=yi.findIndex(a=>a.key==="view");i<0&&(i=0);let o=()=>{let d=7+yi.length*2+2,c=ws(t,{contentHeight:d,title:"Imported session"}),l=c.contentW,f=[{label:"session: ",value:n},{label:"from: ",value:s},{label:"cwd: ",value:r}],u=0;for(let p of f)t.moveTo(c.contentX,c.contentY+u),t.dim.noFormat(` ${p.label}`),t.noFormat(xc(p.value,l-p.label.length-2)),u++;u++,t.moveTo(c.contentX,c.contentY+u),t.noFormat(" What do you want to do?"),u+=2;for(let p=0;p<yi.length;p++){let g=yi[p];if(!g)continue;let w=` ${p===i?"\u276F":" "} ${g.label}`;t.moveTo(c.contentX,c.contentY+u),p===i?t.brightWhite.bgBlue.noFormat(oh(w,l)):t.noFormat(w),u++,t.moveTo(c.contentX,c.contentY+u),t.dim.noFormat(` ${g.description}`),u++}return u++,t.moveTo(c.contentX,c.contentY+u),t.dim.noFormat(" \u2191/\u2193 navigate \xB7 Enter select \xB7 f/v jump \xB7 Esc back"),c};return o(),t.hideCursor(),await new Promise(a=>{let d=!1,c=()=>{d||(d=!0,t.off("key",u),t.off("resize",f),t.grabInput(!1),t.hideCursor(!1),t.moveTo(1,1).eraseDisplayBelow())},l=p=>{c(),a(p)},f=()=>{d||o()},u=(p,g,h)=>{let w=Rk(p,h);if(!w)return;let v=Ck(i,w);if(v.kind==="cancel"){l("cancel");return}if(v.kind==="back"){l("back");return}if(v.kind==="resolve"){l(v.action);return}v.selected!==i&&(i=v.selected,o())};t.grabInput({}),t.on("key",u),t.on("resize",f)})}function Rk(t,e){return t==="UP"?{kind:"up"}:t==="DOWN"?{kind:"down"}:t==="ENTER"||t==="KP_ENTER"?{kind:"enter"}:t==="ESCAPE"?{kind:"back"}:t==="CTRL_C"||t==="CTRL_D"?{kind:"cancel"}:e?.isCharacter?{kind:"char",ch:t}:null}async function ih(t,e,n){let s=He(e.sessionId),r=e.title??Be(e.cwd),i=1,o=[{label:"Launch",hotkey:"l",description:"start a new agent session"},{label:"View transcript",hotkey:"v",description:"open read-only, no agent spawn"}],a=()=>{let d=ws(t,{contentHeight:11,title:"Open session"}),c=d.contentW,l=0;t.moveTo(d.contentX,d.contentY+l),t.dim.noFormat(" session: "),t.noFormat(xc(s,c-10)),l++,t.moveTo(d.contentX,d.contentY+l),t.noFormat(" "+xc(r,c-2)),l++,l++,t.moveTo(d.contentX,d.contentY+l),t.noFormat(" What do you want to do?"),l+=2;for(let f=0;f<o.length;f++){let u=o[f];if(!u)continue;let g=` ${f===i?"\u276F":" "} ${u.label}`;t.moveTo(d.contentX,d.contentY+l),f===i?t.brightWhite.bgBlue.noFormat(oh(g,c)):t.noFormat(g),l++,t.moveTo(d.contentX,d.contentY+l),t.dim.noFormat(` ${u.description}`),l++}l++,t.moveTo(d.contentX,d.contentY+l),t.dim.noFormat(" \u2191/\u2193 navigate \xB7 Enter select \xB7 l/v jump \xB7 Esc back")};return a(),t.hideCursor(),await new Promise(d=>{let c=!1,l=()=>{c=!0},f=p=>{l(),n.pop(),d(p)},u=(p,g,h)=>{if(p==="CTRL_C"||p==="CTRL_D"){f("cancel");return}if(p==="ESCAPE"){f("back");return}if(p==="ENTER"||p==="KP_ENTER"){f(i===0?"launch":"view");return}if(p==="UP"||p==="SHIFT_TAB"){i>0&&(i--,a());return}if(p==="DOWN"||p==="TAB"){i<o.length-1&&(i++,a());return}if(h?.isCharacter){let w=p.toLowerCase();if(w==="l"){f("launch");return}if(w==="v"){f("view");return}if(w==="n"){i<o.length-1&&(i++,a());return}if(w==="p"){i>0&&(i--,a());return}}};n.push({onKey:(p,g,h)=>{c||u(p,g,h)},onResize:()=>{c||a()}})})}function xc(t,e){return e<=1?"":t.length<=e?t:t.slice(0,Math.max(0,e-1))+"\u2026"}function oh(t,e){return t.length>=e?t.slice(0,e):t+" ".repeat(e-t.length)}var yi,Ac=V(()=>{"use strict";ue();Yt();ga();yi=[{key:"fork-local",label:"Fork locally",hotkey:"f",description:"spawn a local fork \u2014 original imported copy stays as-is"},{key:"view",label:"View transcript",hotkey:"v",description:"open read-only, no agent spawn"}]});function Ec(){return{filters:{cwdOnly:!1,hostFilter:"__local",includeNonInteractive:!1}}}async function Pc(t,e){process.stdout.write("\x1B[<u"),process.stdout.write("\x1B[?2004l"),process.stdout.write("\x1B[>4;0m"),process.stdout.write("\x1B[>5;0m"),process.stdout.write("\x1B[?1000l"),process.stdout.write("\x1B[?1002l"),process.stdout.write("\x1B[?1006l"),process.stdout.write("\x1B[?1l"),process.stdout.write("\x1B>");let n=e.prefs??Ec();e.prefs===void 0&&e.currentSessionId!==void 0&&e.sessions.find(M=>M.sessionId===e.currentSessionId)?.importedFromMachine&&(n.filters.hostFilter="__all");let s=Tc(e.sessions,e.cwd),r=k=>{let M=k;return n.filters.cwdOnly&&(M=M.filter(_=>_.cwd===e.cwd)),n.filters.includeNonInteractive||(M=M.filter(_=>_.interactive===!0)),M=$k(M,n.filters.hostFilter),M},i=r(s),o={columns:e.config.tui.sessionColumns??cr,cwdMaxWidth:e.config.tui.cwdColumnMaxWidth},a=i.map(k=>ur(k,Date.now())),d=fr(a,o),c=1+i.length,l=0,f=0;if(e.currentSessionId!==void 0){let k=i.findIndex(M=>M.sessionId===e.currentSessionId);k>=0&&(l=k+1)}let u=!1,p="",g=120,h=!1,w=0,v="normal",b=null,x=!1,C="input",O=new un({history:[],collapsePastes:!1}),q=[],W=!1,Q=0,N=0,F=null,U=!1,J="",ie=null,be=!1,te=new un({history:[]});e.initialPrompt&&te.setBuffer(e.initialPrompt);let X=e.config.tui.promptHistoryMaxEntries;zr(P.globalTuiHistoryFile()).then(k=>{let M=k.length>X?k.slice(k.length-X):k;te.setHistory(M)}).catch(()=>{});let Ie=Rc(t),Y=bs(t),xe=0,Is="",Nt=0,Pt=[],lt=1,vt=0,zn=0,Sr=0,we="",kr=[],Jn=1,Ss=0,Kn=[],Qe=1,mn=0,ks=0,xr=0,Me=()=>{Ie=Rc(t),Y=bs(t);let k=Math.max(10,Y-Cc);Nt=Math.max(10,Y-ah);let M=Math.max(10,Y-8);Is=Mk(e.cwd,M);let _=te.state();Pt=pn(_.buffer,Nt);let K=Wn(Pt,_,ya);lt=K.rendered,vt=K.windowStart,zn=K.cursorVisualRow,Sr=K.cursorVisualCol;let ce=6+lt,ve=Math.max(3,Ie-ce);xe=Math.min(i.length,ve),we=Dn(lr,d,k,o).padEnd(k),kr=a.map(Ae=>Dn(Ae,d,k,o).padEnd(k))},Dt=()=>{a=i.map(k=>ur(k,Date.now())),d=fr(a,o),c=1+i.length,Me()},Oe=()=>{let k=r(s);u&&p.length>0?i=k.filter(M=>Fk(M,p)):i=k,Dt(),u?(f=0,l=i.length>0?1:0):l>c-1&&(l=Math.max(0,c-1)),f+xe>i.length&&(f=Math.max(0,i.length-xe)),It()},hn=k=>{if(k!==void 0){let M=i.findIndex(_=>_.sessionId===k);if(M>=0){l=M+1,It();return}}l=i.length>0?1:0,f=0,It()},It=()=>{if(l===0)return;let k=l-1;k<f?f=k:k>=f+xe?f=k-xe+1:f+xe>i.length&&(f=Math.max(0,i.length-xe))},Vn=()=>Math.max(2,Y-2),Yn=()=>{let k=Vn(),M=`\u2500 ${Is} `,_=Math.max(1,k-M.length),K="\u2500".repeat(_);l===0?t.brightBlue.noFormat(`\u256D${M}${K}\u256E`):t.dim.noFormat(`\u256D${M}${K}\u256E`)},xs=()=>{let k=Vn(),M="\u2500".repeat(k);l===0?t.brightBlue.noFormat(`\u2570${M}\u256F`):t.dim.noFormat(`\u2570${M}\u256F`)},Qn=k=>{let M=Vn(),_=Pt[k],K="";_&&(K=(te.state().buffer[_.bufferIdx]??"").slice(_.startCol,_.endCol));let ce=Math.max(0,M-1-K.length),ve=" ".repeat(ce);l===0?(t.brightBlue.noFormat("\u2502"),t.noFormat(` ${K}${ve}`),t.brightBlue.noFormat("\u2502")):(t.dim.noFormat("\u2502"),t.noFormat(` ${K}${ve}`),t.dim.noFormat("\u2502"))},gn=k=>{let M=kr[k]??"",_=i[k],K=_&&_.priority&&_.priority>0?"* ":" ";l===k+1?t.brightWhite.bgBlue.noFormat(`${K}${M}`):t.noFormat(`${K}${M}`)},Gn=()=>{let k=f,M=Math.max(0,i.length-f-xe),_=[];return n.filters.cwdOnly&&_.push("cwd-only"),n.filters.hostFilter!=="__all"&&_.push(n.filters.hostFilter==="__local"?"host: local":`host: ${n.filters.hostFilter}`),n.filters.includeNonInteractive&&_.push("+non-interactive"),k>0&&_.push(`\u2191 ${k} above`),M>0&&_.push(`\u2193 ${M} below`),_.length===0?"":` ${_.join(" \xB7 ")}`},yn=k=>He(k),fe=()=>{Pe(()=>{if(t.moveTo(1,Ht()),v==="confirm-kill"&&b)t.brightYellow.noFormat(` kill ${yn(b.sessionId)}? [y/N]`);else if(v==="confirm-delete"&&b)b.status==="live"?t.brightRed.noFormat(` kill + delete ${yn(b.sessionId)}? [y/N]`):t.brightRed.noFormat(` delete ${yn(b.sessionId)}? [y/N]`);else if(v==="busy"&&b)t.dim.noFormat(` working on ${yn(b.sessionId)}\u2026`);else if(v==="rename"&&b)t.brightYellow.noFormat(` title: ${J}`),t.bgBrightYellow(" "),t.dim.noFormat(" Enter saves \xB7 Esc cancels");else if(ie!==null)t.dim.noFormat(` ${ie}`);else if(u){t.brightYellow.noFormat(` /${p}`),t.bgBrightYellow(" ");let k=i.length===0?" no matches":` ${i.length} match${i.length===1?"":"es"}`;t.dim.noFormat(`${k} \xB7 ^c clears`)}else t.dim.noFormat(Gn());t.styleReset(),t.eraseLineAfter()})},Zt=k=>Jn+1+k,vi=()=>Jn+lt+1,Ge=()=>Jn+lt+3,St=k=>Ge()+1+(k-f),Ht=()=>Ge()+1+xe,ae=()=>{let k=zn-vt;if(k<0||k>=lt)return;let M=3+Sr;t.moveTo(M,Zt(k))},We=()=>{Pe(()=>{t.hideCursor(),Me(),It(),Jn=1,t.moveTo(1,1).eraseDisplayBelow(),Yn(),t(`
|
|
181
|
+
`);for(let k=0;k<lt;k++)Qn(vt+k),t(`
|
|
182
|
+
`);xs(),t(`
|
|
163
183
|
|
|
164
184
|
`),t.dim.noFormat(` ${we}`)(`
|
|
165
185
|
`);for(let k=0;k<xe;k++)gn(f+k),t(`
|
|
166
186
|
`);fe(),t(`
|
|
167
187
|
`),l===0&&(ae(),t.hideCursor(!1))})},wn=()=>{Pe(()=>{t.hideCursor(),t.moveTo(1,1).eraseDisplayBelow(),t.brightWhite.bold.noFormat(" Picker hotkeys")(`
|
|
168
188
|
|
|
169
|
-
`);for(let k of
|
|
170
|
-
`);continue}let[M,_]=k;t.brightCyan.noFormat(` ${M.padEnd(
|
|
189
|
+
`);for(let k of Pk){if(k===null){t(`
|
|
190
|
+
`);continue}let[M,_]=k;t.brightCyan.noFormat(` ${M.padEnd(Ek)}`),t.noFormat(_)(`
|
|
171
191
|
`)}t(`
|
|
172
192
|
`),t.dim.noFormat(" press any key to dismiss")(`
|
|
173
|
-
`)})},Ee=()=>Qe+4,
|
|
174
|
-
`);Pe(()=>{t.hideCursor(),t.moveTo(1,1).eraseDisplayBelow(),Ii(k);for(let K=0;K<Qe;K++)t.moveTo(1,2+K),vn(mn+K,k);t.moveTo(1,2+Qe),en(k);let _=q.length;if(_===0)t.moveTo(1,Ee()),U||(F===null&&M.trim().length===0?(t.dim.noFormat(" type a query in the box above, then press Enter"),t.eraseLineAfter()):F===null&&(t.dim.noFormat(" no matches"),t.eraseLineAfter())),t.moveTo(1,Ee()+1),
|
|
175
|
-
`),ki=k=>{let M=Qe;O.feed({type:"paste",text:k}),bn(),Qe!==M?tn():Rr()},Mr=async()=>{let k=Si().trim();if(k.length!==0){if(i.length===0){F="no sessions in view to search",tn();return}U=!0,F=null,tn();try{let M=await
|
|
176
|
-
`);nn="";let ve=M.slice(K+Ai.length);if(x)C==="input"&&!U&&ki(ce);else if(l===0&&!u){te.feed({type:"paste",text:ce});let Ae=te.state(),Mt=pn(Ae.buffer,Nt);
|
|
193
|
+
`)})},Ee=()=>Qe+4,As=2,Le=0,S=()=>{Ie=Rc(t);let k=Math.max(2,Ie-(Qe+3)-As);return Math.max(1,Math.floor(k/2))},Ar=()=>{let k=S();Q<Le?Le=Q:Q>=Le+k&&(Le=Q-k+1),Le+k>q.length&&(Le=Math.max(0,q.length-k)),Le<0&&(Le=0)},Ii=k=>{Y=bs(t);let M=Math.max(2,Y-2),_="\u2500 Find sessions ",K="\u2500".repeat(Math.max(1,M-_.length));k?t.brightBlue.noFormat(`\u256D${_}${K}\u256E`):t.dim.noFormat(`\u256D${_}${K}\u256E`),t.styleReset()},bn=()=>{Y=bs(t),Ss=Math.max(10,Y-ah);let k=O.state();Kn=pn(k.buffer,Ss);let M=Wn(Kn,k,Tk);Qe=M.rendered,mn=M.windowStart,ks=M.cursorVisualRow,xr=M.cursorVisualCol},vn=(k,M)=>{Y=bs(t);let _=Math.max(2,Y-2),K=Kn[k],ce="";K&&(ce=(O.state().buffer[K.bufferIdx]??"").slice(K.startCol,K.endCol));let ve=Math.max(0,_-1-ce.length),Ae=" ".repeat(ve);M?(t.brightBlue.noFormat("\u2502"),t.noFormat(` ${ce}${Ae}`),t.brightBlue.noFormat("\u2502")):(t.dim.noFormat("\u2502"),t.noFormat(` ${ce}${Ae}`),t.dim.noFormat("\u2502")),t.styleReset()},en=k=>{Y=bs(t);let M=Math.max(2,Y-2),_="\u2500".repeat(M);k?t.brightBlue.noFormat(`\u2570${_}\u256F`):t.dim.noFormat(`\u2570${_}\u256F`),t.styleReset()},In=()=>3+xr,Xn=()=>2+(ks-mn),Cr=()=>{let k=C==="input";Pe(()=>{k&&t.hideCursor(),t.moveTo(1,1),Ii(k);for(let M=0;M<Qe;M++)t.moveTo(1,2+M),vn(mn+M,k);t.moveTo(1,2+Qe),en(k),k&&(t.moveTo(In(),Xn()),t.hideCursor(!1))})},Rr=()=>{Pe(()=>{t.hideCursor();for(let k=0;k<Qe;k++)t.moveTo(1,2+k),vn(mn+k,!0);t.moveTo(In(),Xn()),t.hideCursor(!1)})},Sn={user:"user",agent:"agent",thought:"thought",tool:"tool","tool-input":"tool-input"},Tr=(k,M)=>{let _=q[k];if(!_)return{rowBudget:20,line1:"",line2:"",focusedRow:!1};let K=bs(t),ce=Math.max(20,K-Cc),ve=He(_.sessionId),Ae=_.title??Be(_.cwd),Mt=M&&_.snippets.length>1?` [${N+1}/${_.snippets.length}]`:M&&_.totalMatches>_.snippets.length?` [${_.snippets.length} of ${_.totalMatches}]`:"",ts=`${ve} ${_.status==="live"?"live":"cold"}`,ns=Math.max(5,ce-ts.length-Mt.length-2),Ut=ii(Ae,ns),Re=`${ts} ${Ut}${Mt}`.padEnd(ce),ze=_.snippets[M?N:0],$t=ze?Sn[ze.kind]??ze.kind:"",kt=ze?.toolName?`${$t} \xB7 ${ze.toolName}`:$t,ft=Math.max(10,ce-kt.length-6),pt=ze?ii(ze.text,ft):"",Es=ze?` ${kt} ${pt}`:" (no snippet)";return{rowBudget:ce,line1:Re,line2:Es.padEnd(ce+Cc),focusedRow:M}},Er=(k,M)=>{let{line1:_,focusedRow:K}=Tr(k,M);K?t.brightWhite.bgBlue.noFormat(`\u276F ${_}`):t.noFormat(` ${_}`),t.styleReset()},Pr=(k,M)=>{let{line2:_}=Tr(k,M);t.dim.noFormat(_),t.styleReset()},Cs=()=>{if(U)t.dim.noFormat(" searching\u2026"),t.styleReset(),t.eraseLineAfter();else if(F!==null)t.brightRed.noFormat(` ${F}`),t.styleReset(),t.eraseLineAfter();else if(C==="input")q.length>0?t.dim.noFormat(" Enter to search \xB7 \u2193 browse results \xB7 Esc cancel"):t.dim.noFormat(" Enter to search \xB7 Esc cancel"),t.styleReset(),t.eraseLineAfter();else{let k=q.length,M=W?" \xB7 truncated":"",_=k>0?` ${k} ${k===1?"session":"sessions"} match${M} \xB7 `:" ";t.dim.noFormat(`${_}\u2191 edit query \xB7 Up/Down sessions \xB7 n/p snippets \xB7 Enter open \xB7 Esc back`),t.styleReset(),t.eraseLineAfter()}},tn=()=>{bn();let k=C==="input",M=O.state().buffer.join(`
|
|
194
|
+
`);Pe(()=>{t.hideCursor(),t.moveTo(1,1).eraseDisplayBelow(),Ii(k);for(let K=0;K<Qe;K++)t.moveTo(1,2+K),vn(mn+K,k);t.moveTo(1,2+Qe),en(k);let _=q.length;if(_===0)t.moveTo(1,Ee()),U||(F===null&&M.trim().length===0?(t.dim.noFormat(" type a query in the box above, then press Enter"),t.eraseLineAfter()):F===null&&(t.dim.noFormat(" no matches"),t.eraseLineAfter())),t.moveTo(1,Ee()+1),Cs();else{Ar();let K=S(),ce=C!=="input";for(let ve=0;ve<K;ve++){let Ae=Le+ve;t.moveTo(1,Ee()+ve*2),Ae<_?Er(Ae,ce&&Ae===Q):t.eraseLineAfter(),t.moveTo(1,Ee()+ve*2+1),Ae<_?Pr(Ae,ce&&Ae===Q):t.eraseLineAfter()}t.moveTo(1,Ee()+K*2),Cs()}k&&(t.moveTo(In(),Xn()),t.hideCursor(!1))})},kn=(k,M)=>{let _=k-Le;_<0||_>=S()||Pe(()=>{t.moveTo(1,Ee()+_*2),Er(k,M),t.moveTo(1,Ee()+_*2+1),Pr(k,M)})},nt=()=>{Pe(()=>{t.moveTo(1,Ee()+S()*2),Cs()})},ut=()=>{Pe(()=>{let k=S(),M=q.length,_=C!=="input";for(let K=0;K<k;K++){let ce=Le+K;t.moveTo(1,Ee()+K*2),ce<M?Er(ce,_&&ce===Q):t.eraseLineAfter(),t.moveTo(1,Ee()+K*2+1),ce<M?Pr(ce,_&&ce===Q):t.eraseLineAfter()}t.moveTo(1,Ee()+k*2),Cs()})},Si=()=>O.state().buffer.join(`
|
|
195
|
+
`),ki=k=>{let M=Qe;O.feed({type:"paste",text:k}),bn(),Qe!==M?tn():Rr()},Mr=async()=>{let k=Si().trim();if(k.length!==0){if(i.length===0){F="no sessions in view to search",tn();return}U=!0,F=null,tn();try{let M=await lp(e.target,k,{sessionIds:i.map(_=>_.sessionId)});q=M.results,W=M.truncated,Q=0,N=0,Le=0,C=M.results.length>0?"results":"input",bn()}catch(M){F=`search failed: ${M.message}`}finally{U=!1,tn()}}},xn=()=>{},$r=()=>{Pe(()=>{let k=l===0;k&&t.hideCursor(),t.moveTo(1,Jn),Yn(),t.moveTo(1,vi()),xs();for(let M=0;M<lt;M++)t.moveTo(1,Zt(M)),Qn(vt+M);k&&(ae(),t.hideCursor(!1))})},xi=()=>{Pe(()=>{let k=te.state();Pt=pn(k.buffer,Nt);let M=Wn(Pt,k,ya);vt=M.windowStart,zn=M.cursorVisualRow,Sr=M.cursorVisualCol;let _=l===0;_&&t.hideCursor();for(let K=0;K<lt;K++)t.moveTo(1,Zt(K)),Qn(vt+K);_&&(ae(),t.hideCursor(!1))})},Lc=k=>{k<f||k>=f+xe||Pe(()=>{t.moveTo(1,St(k)),gn(k)})},va=()=>{Pe(()=>{for(let k=0;k<xe;k++){let M=Ge()+1+k,_=f+k;_<i.length?(t.moveTo(1,M),gn(_)):t.moveTo(1,M).eraseLineAfter()}fe()})},Zn=()=>{Pe(()=>{t.moveTo(1,Ge()),t.dim.noFormat(` ${we}`);for(let k=0;k<xe;k++){let M=Ge()+1+k,_=f+k;_<i.length?(t.moveTo(1,M),gn(_)):t.moveTo(1,M).eraseLineAfter()}fe(),l===0&&(ae(),t.hideCursor(!1))})},Xe=!1,nn="",st=null,Rs=null,Ts="\x1B[200~",Ai="\x1B[201~",es=k=>{let M=k.toString("binary");if(!Xe&&M===""&&Rs){Rs();return}if(Xe){let K=M.indexOf(Ai);if(K===-1){nn+=M;return}nn+=M.slice(0,K),Xe=!1;let ce=Buffer.from(nn,"binary").toString("utf-8").replace(/\r\n?/g,`
|
|
196
|
+
`);nn="";let ve=M.slice(K+Ai.length);if(x)C==="input"&&!U&&ki(ce);else if(l===0&&!u){te.feed({type:"paste",text:ce});let Ae=te.state(),Mt=pn(Ae.buffer,Nt);Wn(Mt,Ae,ya).rendered!==lt?We():xi()}ve.length>0&&st&&st(Buffer.from(ve,"binary"));return}let _=M.indexOf(Ts);if(_===-1){st?.(k);return}_>0&&st?.(Buffer.from(M.slice(0,_),"binary")),M=M.slice(_+Ts.length),Xe=!0,M.length>0&&es(Buffer.from(M,"binary"))};return We(),await new Promise(k=>{let M=!1,_=null,K=!1,ce=!1,ve=[],Ae=E=>{ve.push(E)},Mt=()=>{ve.pop(),M||ve[ve.length-1]?.onResize()},ts={push:Ae,pop:Mt};xn=()=>{O=new un({history:[],collapsePastes:!1}),q=[],W=!1,Q=0,N=0,Le=0,F=null,U=!1,C="input",x=!1,Mt()};let ns=(E,j,oe)=>{$t(),ve[ve.length-1]?.onKey(E,j,oe)},Ut=()=>{M||ve[ve.length-1]?.onResize()},Re=()=>{if(M)return;M=!0,ve.length=0,_&&(clearInterval(_),_=null),t.off("key",ns),t.off("resize",Ut),process.stdout.write("\x1B[?2004l");let E=t;E.stdin&&st&&(E.stdin.removeListener("data",es),E.stdin.on("data",st),st=null),Xe=!1,nn="",t.grabInput(!1),t.hideCursor(!1),t.moveTo(1,Ht()+1),t(`
|
|
177
197
|
`)},ze=()=>{if(M||ve.length>1||v!=="normal"||u||K||ce)return;let E=l>0?i[l-1]?.sessionId:void 0;K=!0,pt(E,{silent:!0}).finally(()=>{K=!1})},$t=()=>{M||(_&&clearInterval(_),_=setInterval(ze,3e3))},kt=()=>(Re(),k({kind:be?"exit":"abort"}),!0),ft=()=>{let E=a.map(j=>`${j.session}|${j.upstream}|${j.host}|${j.state}|${j.agent}|${j.model}|${j.age}|${j.title}|${j.cwd}|${j.cost}`).join(`
|
|
178
198
|
`);return`${l}:${f}:${ie??""}
|
|
179
|
-
${E}`},pt=async(E,j={})=>{try{let oe=j.silent?ft():"",$=c,ee=await cn(e.target,{includeNonInteractive:!0}),G=E??(l>0?i[l-1]?.sessionId:void 0);if(s=Tc(ee,e.cwd),Oe(),G!==void 0){let le=i.findIndex(Ze=>Ze.sessionId===G);le>=0?l=le+1:l=0}if(l>c-1&&(l=Math.max(0,c-1)),f+xe>i.length&&(f=Math.max(0,i.length-xe)),It(),j.silent&&ft()===oe)return;c===$?
|
|
199
|
+
${E}`},pt=async(E,j={})=>{try{let oe=j.silent?ft():"",$=c,ee=await cn(e.target,{includeNonInteractive:!0}),G=E??(l>0?i[l-1]?.sessionId:void 0);if(s=Tc(ee,e.cwd),Oe(),G!==void 0){let le=i.findIndex(Ze=>Ze.sessionId===G);le>=0?l=le+1:l=0}if(l>c-1&&(l=Math.max(0,c-1)),f+xe>i.length&&(f=Math.max(0,i.length-xe)),It(),j.silent&&ft()===oe)return;c===$?Zn():We()}catch(oe){if(j.silent)return;ie=`refresh failed: ${oe.message}`,We()}},Es=async E=>{if(!b)return;let j=b;v="busy",fe();try{await ap(e.target,j.sessionId,E),v="normal",b=null,J="",await pt(j.sessionId)}catch(oe){v="normal",b=null,J="",ie=`rename failed: ${oe.message}`,fe()}},_r=async E=>{try{await cp(e.target,E.sessionId),ie="title regen queued (press r to refresh)",fe()}catch(j){ie=`regen failed: ${j.message}`,fe()}},Ci=async E=>{let oe=(E.priority&&E.priority>0?E.priority:0)>0?null:1,$=oe??0;for(let G of s)G.sessionId===E.sessionId&&(G.priority=$>0?$:void 0);let ee=E.sessionId;s=Tc(s,e.cwd),Oe(),hn(ee),We(),ie=$>0?"priority: high":"priority: normal",fe();try{await dp(e.target,E.sessionId,oe)}catch(G){ie=`priority failed: ${G.message}`,fe()}},Ia=async()=>{if(ce)return;ce=!0;let E=l>0?i[l-1]?.sessionId:void 0;ie="syncing agents\u2026",fe();try{let{synced:j,skipped:oe,agents:$}=await sp(e.target);await pt(E),ie=`synced ${j} new (${oe} known) from ${$} agent${$===1?"":"s"}`,fe()}catch(j){ie=`sync failed: ${j.message}`,fe()}finally{ce=!1}},Ri=async E=>{if(!b)return;let j=b;v="busy",fe();try{E==="kill"?await op(e.target,j.sessionId):await up(e.target,j.sessionId),v="normal",b=null,j.sessionId===e.currentSessionId&&(be=!0);let oe;if(E==="kill")oe=j.sessionId;else{let $=i.findIndex(ee=>ee.sessionId===j.sessionId);$>=0&&(oe=i[$+1]?.sessionId??i[$-1]?.sessionId)}await pt(oe)}catch(oe){v="normal",b=null,ie=`${E} failed: ${oe.message}`,fe()}},Fr=(E,j)=>{E===0!=(j===0)&&($r(),j===0?(t.hideCursor(!1),ae()):t.hideCursor())},Te=E=>{let j=Math.min(c-1,Math.max(0,l+E));if(j===l)return;let oe=l;l=j,It(),Pe(()=>{va(),Fr(oe,l)})},An=()=>ie===null?!1:(ie=null,fe(),!0),sn=()=>{wn(),Ae({onKey:E=>{if(E==="CTRL_C"){Re(),k({kind:"abort"});return}Mt()},onResize:()=>wn()})},Cn=E=>{let j=null,oe=null,$=!0,ee=()=>{Pe(()=>{if(t.hideCursor(),t.moveTo(1,1).eraseDisplayBelow(),t.brightWhite.bold.noFormat(` Session info \u2014 ${He(E.sessionId)}`)(`
|
|
180
200
|
|
|
181
201
|
`),$)t.dim.noFormat(" loading\u2026")(`
|
|
182
202
|
`);else if(oe!==null)t.brightRed.noFormat(` ${oe}`)(`
|
|
@@ -184,91 +204,91 @@ ${E}`},pt=async(E,j={})=>{try{let oe=j.silent?ft():"",$=c,ee=await cn(e.target,{
|
|
|
184
204
|
`);t(`
|
|
185
205
|
`),t.dim.noFormat(" Esc / ^C to return")(`
|
|
186
206
|
`)})};ee(),Ae({onKey:G=>{if(G==="ESCAPE"||G==="CTRL_C"){Mt();return}},onResize:()=>ee()}),(async()=>{try{let G=await fetch(`${e.target.baseUrl}/v1/sessions/${encodeURIComponent(E.sessionId)}/export`,{headers:{Authorization:`Bearer ${e.target.token}`}});if(!G.ok)throw new Error(`daemon returned HTTP ${G.status}`);let le=await G.json(),Ze=Bt(le),Je=zd(Ze,E.status);j=Qo(Je,!1).replace(/\n$/,"").split(`
|
|
187
|
-
`)}catch(G){oe=`failed to load info: ${G.message}`}finally{$=!1,ee()}})()},rn=()=>{if(i.length===0){ie="no sessions to search",fe();return}O=new un({history:[],collapsePastes:!1}),q=[],W=!1,Q=0,N=0,Le=0,F=null,U=!1,C="input",x=!0,bn(),tn(),Ae({onKey:(j,oe,$)=>{if(C==="input"){if(U)return;if(j==="ESCAPE"||j==="CTRL_C"){xn();return}if(j==="ENTER"||j==="KP_ENTER"){if(Si().trim().length===0)return;Mr();return}if((j==="DOWN"||j==="TAB"||j==="CTRL_N")&&q.length>0){C="results",Q=0,N=0,Pe(()=>{Cr(),kn(0,!0),nt(),t.hideCursor()});return}let ee=O.state(),G=null;if($?.isCharacter)G={type:"char",ch:j};else{let _t=ha(j);_t!==null&&(G={type:"key",name:_t})}if(G===null){t.moveTo(In(),
|
|
188
|
-
`),process.once("SIGCONT",j),process.kill(process.pid,"SIGTSTP"))}}_=setInterval(ze,3e3)})}function Rc(t){let e=t.height;return typeof e=="number"&&Number.isFinite(e)&&e>0?e:24}function ws(t){let e=t.width;return typeof e=="number"&&Number.isFinite(e)&&e>0?e:80}function Pk(t,e){let n="Create new session in ",s=Math.max(1,e-n.length);return n+ii(Be(t),s)}function Tc(t,e){let n=r=>r.priority&&r.priority>0?r.priority:0,s=r=>{let i=r.status==="live",o=n(r)>0;return i&&r.awaitingInput?5:i&&r.busy?4:i&&o?3:i?2:o?1:0};return[...t].sort((r,i)=>{let o=s(i)-s(r);if(o!==0)return o;let a=n(i)-n(r);return a!==0?a:i.updatedAt.slice(0,16).localeCompare(r.updatedAt.slice(0,16))})}function Mk(t,e){return e==="__all"?t:e==="__local"?t.filter(n=>!n.importedFromMachine||!!n.upstreamSessionId):t.filter(n=>n.importedFromMachine===e&&!n.upstreamSessionId)}function $k(t,e){let n=new Set;for(let i of e)i.importedFromMachine&&!i.upstreamSessionId&&n.add(i.importedFromMachine);let s=["__local",...[...n].sort(),"__all"],r=s.indexOf(t);return r===-1?"__local":s[(r+1)%s.length]??"__local"}function _k(t,e){if(e.length===0)return!0;let n=e.toLowerCase(),s=[He(t.sessionId),t.upstreamSessionId??"",t.agentId??"",t.title??"",t.cwd,Be(t.cwd)];for(let r of s)if(r.toLowerCase().includes(n))return!0;return!1}var Cc,ya,Rk,oh,Tk,Ek,ah=V(()=>{"use strict";Jo();ue();Yt();qo();oo();oc();Ic();Ac();fc();ls();Jd();Cc=2,ya=4,Rk=4,oh=4,Tk=20,Ek=[["Composer","type prompt for new session; Enter creates + submits"],["\u2193 from composer","drop focus into session list"],null,["\u2191 / \u2193, n / p, ^p / ^n","navigate sessions"],["PgUp / PgDn","page up / page down"],["Home / End","first / last"],["Enter","open selected session"],["v","view-only (open transcript without spawning the agent)"],null,["/","search sessions (metadata)"],["^f","find in session history (content + tool inputs)"],["o","toggle cwd-only filter"],["h","cycle host filter (local / <peer> / all)"],["i","show info for the selected session"],["I","toggle include-cat filter"],["r","refresh from daemon"],["s","sync sessions from installed agents"],null,["k","kill the selected live session"],["d","delete the selected session (kills first if live)"],["t","retitle the selected session"],["T","regenerate title + synopsis via agent (live session)"],["*","toggle high priority on the selected session (floats to top)"],null,["?","toggle this help"],["q / Esc / ^C / ^D","quit picker (detach)"]]});function wi(t){if(t.length===0)return"";let e=t[0]??"";for(let n=1;n<t.length;n++){let s=t[n]??"",r=0;for(;r<e.length&&r<s.length&&e[r]===s[r];)r+=1;if(e=e.slice(0,r),e.length===0)break}return e}function dh(t){let{matches:e,firstLine:n}=t;if(e.length===0)return null;let s=n.indexOf(" "),r=s===-1?n:n.slice(0,s),i=s===-1?"":n.slice(s);if(e.length===1){let a=e[0]??"",d=i.startsWith(" ")?"":" ";return a+d+i}let o=wi(e);return o.length<=r.length?null:o+i}var wa=V(()=>{"use strict"});import*as ch from"os";async function bi(t,e,n={}){let s=n.defaultCwd??await $m(e.cwd)??ch.homedir();Ir();let r=He(e.sessionId),i=Be(e.cwd),o=n.title??"Fork locally \u2014 choose cwd",a=n.intro??"Pick a local cwd for this session:",d=[{label:"session: ",value:r},...e.importedFromMachine?[{label:"from: ",value:e.importedFromMachine}]:[],{label:"cwd: ",value:i}],c=s,l=null,f=!1,u=null,p=()=>{let v=d.length+6;u=ys(t,{contentHeight:v,title:o});let b=u.contentW,x=0;for(let C of d)t.moveTo(u.contentX,u.contentY+x),t.dim.noFormat(` ${C.label}`),t.noFormat(Mc(C.value,b-C.label.length-2)),x++;x++,t.moveTo(u.contentX,u.contentY+x),t.noFormat(` ${a}`),x+=2,h(x),x+=2,l!==null?(t.moveTo(u.contentX,u.contentY+x),t.red.noFormat(` ${Mc(l,b-2)}`)):(t.moveTo(u.contentX,u.contentY+x),t.dim.noFormat(" Enter accept \xB7 Tab complete \xB7 Esc back \xB7 ^U clear"))},g=()=>d.length+3,h=v=>{if(!u)return;let b=v??g();t.moveTo(u.contentX,u.contentY+b).eraseLineAfter(),t.moveTo(u.x+u.w-1,u.contentY+b),t.dim.noFormat("\u2502"),t.moveTo(u.contentX,u.contentY+b),t.bold.noFormat(" cwd: ");let x=u.contentW-6-2;t.noFormat(Fk(c,x)),f||t.bgWhite(" ")},w=()=>{if(h(),!u)return;let v=g()+2;t.moveTo(u.contentX,u.contentY+v).eraseLineAfter(),t.moveTo(u.x+u.w-1,u.contentY+v),t.dim.noFormat("\u2502"),t.moveTo(u.contentX,u.contentY+v),l!==null?t.red.noFormat(` ${Mc(l,u.contentW-2)}`):t.dim.noFormat(" Enter accept \xB7 Tab complete \xB7 Esc back \xB7 ^U clear")};return p(),await new Promise(v=>{let b=!1,x=()=>{b||(b=!0,t.off("key",q),t.off("resize",O),t.grabInput(!1),t.hideCursor(!1),t.moveTo(1,1).eraseDisplayBelow())},C=W=>{x(),v(W)},O=()=>{b||p()},q=(W,Q,N)=>{if(!f){if(W==="ENTER"||W==="KP_ENTER"){let F=c;f=!0,l=null,w(),pi(F).then(U=>{if(f=!1,U.ok){C({kind:"ok",path:U.path});return}l=U.reason,w()});return}if(W==="ESCAPE"){C({kind:"back"});return}if(W==="CTRL_C"||W==="CTRL_D"){C({kind:"cancel"});return}if(W==="TAB"){f=!0,_m(c).then(F=>{if(f=!1,F.matches.length===0)return;let U;if(F.matches.length===1)U=F.prefix+F.matches[0];else{let J=wi(F.matches);if(J.length<=F.basePrefix.length)return;U=F.prefix+J}U!==c&&(c=U,l=null,w())});return}if(W==="BACKSPACE"){c.length>0&&(c=c.slice(0,-1),l=null,w());return}if(W==="CTRL_U"){c="",l=null,w();return}if(W==="CTRL_W"){let F=c.replace(/[/\s]+$/,""),U=Math.max(F.lastIndexOf("/"),F.lastIndexOf(" "));c=U>=0?F.slice(0,U+1):"",l=null,w();return}if(N?.isCharacter){c+=W,l=null,w();return}}};t.grabInput({}),t.on("key",q),t.on("resize",O)})}function Mc(t,e){return e<=1?"":t.length<=e?t:t.slice(0,Math.max(0,e-1))+"\u2026"}function Fk(t,e){return e<=1?"":t.length<=e?t:"\u2026"+t.slice(t.length-(e-1))}var lh=V(()=>{"use strict";ue();Yt();rc();wa();ga()});function Nk(t){let e=t.findIndex(n=>n.id===Ok);return e===-1?0:e}async function fh(t,e){Ir();let n=Nk(e),s=0,r=()=>{let a=kc(t)-8;return Math.max(1,Math.min(Lk,e.length,a))},i=()=>{let a=r();n<s?s=n:n>=s+a&&(s=n-a+1);let d=Math.max(0,e.length-a);s>d&&(s=d),s<0&&(s=0)},o=()=>{i();let a=r(),d=a+4,c=Math.min(Bk,Math.max(40,Sc(t)-8)),l=ys(t,{contentHeight:d,contentWidth:c,title:"Select agent"}),f=l.contentW,u=0;t.moveTo(l.contentX,l.contentY+u),t.noFormat(" Which agent should this session use?"),u+=2;let p=Math.min(e.length,s+a);for(let h=s;h<p;h++){let w=e[h];if(!w)continue;let v=h===n?"\u276F":" ",b=w.description??w.name,x=` ${v} ${w.id}`;if(t.moveTo(l.contentX,l.contentY+u),h===n){let C=`${x} ${b}`;t.brightWhite.bgBlue.noFormat(Dk(uh(C,f),f))}else{t.noFormat(x);let C=f-x.length-2;C>1&&t.dim.noFormat(` ${uh(b,C)}`)}u++}u++,t.moveTo(l.contentX,l.contentY+u);let g=e.length>a?` (${n+1}/${e.length})`:"";return t.dim.noFormat(` \u2191/\u2193 navigate \xB7 Enter this session \xB7 s set default \xB7 Esc back${g}`),l};return o(),t.hideCursor(),await new Promise(a=>{let d=!1,c=()=>{d||(d=!0,t.off("key",g),t.off("resize",f),t.grabInput(!1),t.hideCursor(!1),t.moveTo(1,1).eraseDisplayBelow())},l=h=>{c(),a(h)},f=()=>{d||o()},u=()=>{n<e.length-1&&(n++,o())},p=()=>{n>0&&(n--,o())},g=(h,w,v)=>{if(h==="CTRL_C"||h==="CTRL_D"){l({kind:"cancel"});return}if(h==="ESCAPE"){l({kind:"back"});return}if(h==="ENTER"||h==="KP_ENTER"){let b=e[n];b&&l({kind:"select",agentId:b.id,persist:!1});return}if(h==="UP"||h==="SHIFT_TAB"){p();return}if(h==="DOWN"||h==="TAB"){u();return}if(v?.isCharacter){let b=h.toLowerCase();if(b==="s"){let x=e[n];x&&l({kind:"select",agentId:x.id,persist:!0});return}if(b==="j"){u();return}if(b==="k"){p();return}}};t.grabInput({}),t.on("key",g),t.on("resize",f)})}function uh(t,e){return e<=1?"":t.length<=e?t:t.slice(0,Math.max(0,e-1))+"\u2026"}function Dk(t,e){return t.length>=e?t.slice(0,e):t+" ".repeat(e-t.length)}var Ok,Lk,Bk,ph=V(()=>{"use strict";ga();Ok="opencode",Lk=20,Bk=88});import*as hh from"fs";import*as gh from"os";import*as ba from"path";function yh(t,e){let n=e;for(;n>0;){let s=t[n-1]??"";if(/\s/.test(s)){if(s===" "&&t[n-2]==="\\"){n-=2;continue}break}n-=1}return n===e?null:{token:t.slice(n,e),start:n}}function Hk(t){return t.length===0?!1:t.includes("/")?!0:t==="~"||t==="."||t===".."}function Uk(t){return t.replace(/\\ /g," ")}function mh(t){return t.replace(/ /g,"\\ ")}function jk(t){let e=t.lastIndexOf("/");return e===-1?{dirPrefix:"",base:t}:{dirPrefix:t.slice(0,e+1),base:t.slice(e+1)}}function qk(t,e){let n=t.length===0?".":t;return(n==="~"||n.startsWith("~/"))&&(n=gh.homedir()+n.slice(1)),ba.isAbsolute(n)?n:ba.resolve(e,n)}function Wk(t){let e;try{e=hh.readdirSync(t,{withFileTypes:!0})}catch{return null}return e.map(n=>({name:n.name,isDir:n.isDirectory()}))}function wh(t,e,n=Wk){if(!Hk(t))return null;let s=Uk(t),{dirPrefix:r,base:i}=jk(s),o=qk(r,e),a=n(o);if(a===null)return null;let d=i.startsWith("."),c=a.filter(u=>u.name.startsWith(i)&&(d||!u.name.startsWith(".")));if(c.length===0)return null;let l=c.map(u=>u.isDir?u.name+"/":u.name);if(c.length===1){let u=c[0],p=u.isDir?u.name+"/":u.name;return{replacement:mh(r+p),candidates:l}}let f=wi(c.map(u=>u.name));return{replacement:mh(r+f),candidates:l}}var bh=V(()=>{"use strict";wa()});function vh(t){let e={};if(!t||typeof t!="object")return e;let n=t;typeof n.historyPolicy=="string"&&(e.appliedPolicy=n.historyPolicy),typeof n.clientId=="string"&&n.clientId.length>0&&(e.clientId=n.clientId);let s=n._meta;if(s&&typeof s=="object"){let r=s["hydra-acp"];if(r&&typeof r=="object"){let i=r.turnStartedAt;typeof i=="number"&&(e.turnStartedAt=i)}}return e}function Ih(t){return!t.replayDraining&&!t.amended&&t.pendingTurns>0&&t.queueSize===0&&!t.ownTurnInFlight&&!t.hasInFlightHead}function Sh(t){return t.daemonTurnStartedAt!==void 0?{pendingTurnsDelta:t.pendingTurns===0?1:0,banner:"busy",busySince:t.daemonTurnStartedAt}:{pendingTurnsDelta:t.pendingTurns>0?-t.pendingTurns:0,banner:"ready"}}var kh=V(()=>{"use strict"});import{appendFileSync as zk,statSync as Jk,renameSync as Kk}from"fs";import{nanoid as xh}from"nanoid";import Vk from"terminal-kit";import Yk from"fs/promises";import $c from"path";function Ah(t){if(!Array.isArray(t))return;let e=fs({sessionUpdate:"config_option_update",configOptions:t});return e&&e.kind==="config-options"?e.options:void 0}function Ch(t){switch(t.type){case"send":case"amend":case"queue-edit":case"queue-remove":case"plan-toggle":case"attachment-request":return!0;default:return!1}}async function Eh(t){let e=await Z(),n=t.target??await Wt(e);$h=e.tui.logMaxBytes,n.isLocal&&!t.target&&await ir(e);let s=Vk.terminal;nh(s);let r={},i={showThoughts:e.tui.showThoughts,toolsExpanded:!1,planExpanded:!1,showFileUpdates:e.tui.showFileUpdates,mouseEnabled:e.tui.mouse,inAppSelectionEnabled:al(e),defaultEnterAction:e.tui.defaultEnterAction},o=Ec(),a=!1,d=()=>{a||(s.fullscreen(!0),a=!0)},c=()=>{a&&(s.fullscreen(!1),a=!1,process.stdout.write(`
|
|
189
|
-
`))};d();let l=()=>{a&&(s.fullscreen(!1),a=!1)};process.once("exit",l);let f=t;try{for(;f!==null;)f=await
|
|
207
|
+
`)}catch(G){oe=`failed to load info: ${G.message}`}finally{$=!1,ee()}})()},rn=()=>{if(i.length===0){ie="no sessions to search",fe();return}O=new un({history:[],collapsePastes:!1}),q=[],W=!1,Q=0,N=0,Le=0,F=null,U=!1,C="input",x=!0,bn(),tn(),Ae({onKey:(j,oe,$)=>{if(C==="input"){if(U)return;if(j==="ESCAPE"||j==="CTRL_C"){xn();return}if(j==="ENTER"||j==="KP_ENTER"){if(Si().trim().length===0)return;Mr();return}if((j==="DOWN"||j==="TAB"||j==="CTRL_N")&&q.length>0){C="results",Q=0,N=0,Pe(()=>{Cr(),kn(0,!0),nt(),t.hideCursor()});return}let ee=O.state(),G=null;if($?.isCharacter)G={type:"char",ch:j};else{let _t=ha(j);_t!==null&&(G={type:"key",name:_t})}if(G===null){t.moveTo(In(),Xn());return}O.feed(G);let le=O.state();if(ee.buffer.length===le.buffer.length&&ee.buffer.every((_t,$e)=>_t===le.buffer[$e])&&ee.row===le.row&&ee.col===le.col){t.moveTo(In(),Xn());return}let Je=Qe;bn(),Qe!==Je?tn():Rr();return}if(C==="results"){if(j==="ESCAPE"||j==="CTRL_C"){xn();return}if(j==="CTRL_F"){C="input",ut(),nt(),Cr();return}if(j==="ENTER"||j==="KP_ENTER"){let G=q[Q];if(!G)return;let le=i.find(Je=>Je.sessionId===G.sessionId);if(!!le?.importedFromMachine&&!le.upstreamSessionId){Re();let Je={kind:"attach",sessionId:G.sessionId};le.agentId!==void 0&&(Je.agentId=le.agentId),k(Je);return}(async()=>{let Je=await ih(t,{sessionId:G.sessionId,title:G.title,cwd:G.cwd},ts);if(Je==="cancel"){Re(),k({kind:"abort"});return}if(Je==="back")return;Re();let _t={kind:"attach",sessionId:G.sessionId,readonly:Je==="view"};le?.agentId!==void 0&&(_t.agentId=le.agentId),k(_t)})();return}if($?.isCharacter&&(j==="n"||j==="N")){let G=q[Q];if(!G||G.snippets.length<=1)return;N=(N+1)%G.snippets.length,kn(Q,!0);return}if($?.isCharacter&&(j==="p"||j==="P")){let G=q[Q];if(!G||G.snippets.length<=1)return;N=(N-1+G.snippets.length)%G.snippets.length,kn(Q,!0);return}let ee=G=>{if(G<0&&Q===0){C="input",Pe(()=>{kn(0,!1),nt(),Cr()});return}let le=Math.min(q.length-1,Math.max(0,Q+G));if(le===Q)return;let Ze=Q,Je=Le;Q=le,N=0,Ar(),Le!==Je?ut():(Pe(()=>{kn(Ze,!1),kn(Q,!0)}),nt())};switch(j){case"UP":case"SHIFT_TAB":case"CTRL_P":ee(-1);return;case"DOWN":case"TAB":case"CTRL_N":ee(1);return;case"PAGE_UP":ee(-S());return;case"PAGE_DOWN":ee(S());return;case"HOME":ee(-Q);return;case"END":ee(q.length);return}return}},onResize:()=>tn()})},ss=(E,j,oe)=>{if(v!=="busy"){if(v==="rename"){if(E==="ENTER"||E==="KP_ENTER"){let $=J.trim();if($.length===0){v="normal",b=null,J="",fe();return}Es($);return}if(E==="ESCAPE"||E==="CTRL_C"){v="normal",b=null,J="",fe();return}if(E==="BACKSPACE"){J.length>0&&(J=J.slice(0,-1),fe());return}if(E==="CTRL_U"){J="",fe();return}if(E==="CTRL_W"){let $=J.replace(/\s+$/,""),ee=$.lastIndexOf(" ");J=ee>=0?$.slice(0,ee):"",fe();return}if(oe?.isCharacter){J+=E,fe();return}return}if(v==="confirm-kill"||v==="confirm-delete"){if(oe?.isCharacter&&(E==="y"||E==="Y")){Ri(v==="confirm-kill"?"kill":"delete");return}if(E==="ESCAPE"||E==="CTRL_C"||E==="ENTER"||E==="KP_ENTER"||oe?.isCharacter&&(E==="n"||E==="N")){v="normal",b=null,fe();return}return}if(An(),E==="CTRL_F"){rn();return}if(l===0&&!u){if(E==="ESCAPE"){kt();return}if(E==="ENTER"||E==="KP_ENTER"){Re();let $e=te.expandedText();$e.trim().length===0?k({kind:"new"}):k({kind:"new",prompt:$e});return}if(E==="UP"&&h){let $e=Date.now(),Rn=$e-w;if(w=$e,Rn<g){ae();return}h=!1}if(E==="DOWN"){let $e=te.state(),Rn=$e.historyIndex!==-1||$e.queueIndex!==-1,Ps=Pt.length===0||zn===Pt.length-1;if(!Rn&&Ps&&i.length>0){Te(1);return}}if(E==="PAGE_DOWN"&&(Pt.length===0||zn===Pt.length-1)&&i.length>0){Te(1);return}if(E==="CTRL_P"){i.length>0&&Te(1);return}h=!1;let $=te.state(),ee=null;if(oe?.isCharacter)ee={type:"char",ch:E};else{let $e=ha(E);$e!==null&&(ee={type:"key",name:$e})}if(ee===null){ae();return}let G=te.feed(ee),le=te.state(),Ze=$.buffer.length===le.buffer.length&&$.buffer.every(($e,Rn)=>$e===le.buffer[Rn])&&$.row===le.row&&$.col===le.col;if(G.some($e=>$e.type==="exit")){kt();return}if(Ze){ae();return}let Je=pn(le.buffer,Nt);if(Wn(Je,le,ya).rendered!==lt){We();return}xi();return}if(!u&&oe?.isCharacter&&E==="?"){sn();return}if(u){if(oe?.isCharacter){p+=E,Oe(),We();return}if(E==="BACKSPACE"){p.length>0?(p=p.slice(0,-1),Oe(),We()):(u=!1,Oe(),We());return}if(E==="ESCAPE"||E==="CTRL_C"){u=!1,p="",Oe(),We();return}}if(oe?.isCharacter){if(E==="/"){u=!0,p="",Oe(),We();return}if(E==="n"||E==="N"){Te(1);return}if(E==="p"||E==="P"){Te(-1);return}if(E==="c"||E==="C"){Re(),k({kind:"new"});return}if(E==="q"||E==="Q"){kt();return}if(E==="o"||E==="O"){let $=l>0?i[l-1]?.sessionId:void 0;n.filters.cwdOnly=!n.filters.cwdOnly,Oe(),hn($),We();return}if(E==="h"||E==="H"){let $=l>0?i[l-1]?.sessionId:void 0;n.filters.hostFilter=_k(n.filters.hostFilter,s),Oe(),hn($),We();return}if(E==="i"&&l>0){let $=i[l-1];if(!$)return;Cn($);return}if(E==="I"){let $=l>0?i[l-1]?.sessionId:void 0;n.filters.includeNonInteractive=!n.filters.includeNonInteractive,Oe(),hn($),We();return}if(E==="r"||E==="R"){let $=l>0?i[l-1]?.sessionId:void 0;pt($);return}if(E==="s"||E==="S"){Ia();return}if((E==="v"||E==="V")&&l>0){let $=i[l-1];if(!$)return;Re();let ee={kind:"attach",sessionId:$.sessionId,readonly:!0};$.agentId!==void 0&&(ee.agentId=$.agentId),k(ee);return}if((E==="f"||E==="F")&&l>0){let $=i[l-1];if(!$)return;Re();let ee={kind:"fork",sourceSessionId:$.sessionId,sourceCwd:$.cwd};$.agentId!==void 0&&(ee.sourceAgentId=$.agentId),$.importedFromMachine!==void 0&&(ee.sourceImportedFromMachine=$.importedFromMachine),$.upstreamSessionId!==void 0&&(ee.sourceUpstreamSessionId=$.upstreamSessionId),k(ee);return}if((E==="k"||E==="K")&&l>0){let $=i[l-1];if(!$)return;b={sessionId:$.sessionId,cwd:$.cwd,status:$.status},v="confirm-kill",fe();return}if(E==="t"&&l>0){let $=i[l-1];if(!$)return;b={sessionId:$.sessionId,cwd:$.cwd,status:$.status},J=$.title??"",v="rename",fe();return}if(E==="T"&&l>0){let $=i[l-1];if(!$||$.status!=="live")return;_r({sessionId:$.sessionId});return}if(E==="*"&&l>0){let $=i[l-1];if(!$)return;Ci($);return}if((E==="d"||E==="D")&&l>0){let $=i[l-1];if(!$)return;b={sessionId:$.sessionId,cwd:$.cwd,status:$.status},v="confirm-delete",fe();return}return}switch(E){case"UP":case"SHIFT_TAB":case"CTRL_P":E==="UP"&&(l===1&&(h=!0),w=Date.now()),Te(-1);return;case"DOWN":case"TAB":case"CTRL_N":Te(1);return;case"PAGE_UP":Te(-xe);return;case"PAGE_DOWN":Te(xe);return;case"HOME":Te(1-l);return;case"END":Te(c);return;case"ENTER":case"KP_ENTER":{if(Re(),l===0){k({kind:"new"});return}let $=i[l-1];if(!$){k({kind:"abort"});return}let ee={kind:"attach",sessionId:$.sessionId};$.agentId!==void 0&&(ee.agentId=$.agentId),k(ee);return}case"ESCAPE":case"CTRL_C":case"CTRL_D":kt();return}}};Ae({onKey:(E,j,oe)=>ss(E,j,oe),onResize:()=>{M||We()}});let jt=()=>{t.grabInput({});let E=t;E.stdin&&typeof E.onStdin=="function"&&(st=E.onStdin,E.stdin.removeListener("data",E.onStdin),E.stdin.on("data",es),process.stdout.write("\x1B[?2004h")),t.on("key",ns),t.on("resize",Ut)},rs=()=>{process.stdout.write("\x1B[?2004l");let E=t;E.stdin&&st&&(E.stdin.removeListener("data",es),E.stdin.on("data",st),st=null),Xe=!1,nn="",t.off("key",ns),t.off("resize",Ut),t.grabInput(!1),t.hideCursor(!1)};if(jt(),process.platform!=="win32"){let E=!1,j=()=>{E&&(E=!1,process.stdout.write("\x1B[?1049h"),jt(),M||We())};Rs=()=>{E||M||(E=!0,rs(),process.stdout.write(`\x1B[?1049l\x1B[?7h\x1B[?25h
|
|
208
|
+
`),process.once("SIGCONT",j),process.kill(process.pid,"SIGTSTP"))}}_=setInterval(ze,3e3)})}function Rc(t){let e=t.height;return typeof e=="number"&&Number.isFinite(e)&&e>0?e:24}function bs(t){let e=t.width;return typeof e=="number"&&Number.isFinite(e)&&e>0?e:80}function Mk(t,e){let n="Create new session in ",s=Math.max(1,e-n.length);return n+ii(Be(t),s)}function Tc(t,e){let n=r=>r.priority&&r.priority>0?r.priority:0,s=r=>{let i=r.status==="live",o=n(r)>0;return i&&r.awaitingInput?5:i&&r.busy?4:i&&o?3:i?2:o?1:0};return[...t].sort((r,i)=>{let o=s(i)-s(r);if(o!==0)return o;let a=n(i)-n(r);return a!==0?a:i.updatedAt.slice(0,16).localeCompare(r.updatedAt.slice(0,16))})}function $k(t,e){return e==="__all"?t:e==="__local"?t.filter(n=>!n.importedFromMachine||!!n.upstreamSessionId):t.filter(n=>n.importedFromMachine===e&&!n.upstreamSessionId)}function _k(t,e){let n=new Set;for(let i of e)i.importedFromMachine&&!i.upstreamSessionId&&n.add(i.importedFromMachine);let s=["__local",...[...n].sort(),"__all"],r=s.indexOf(t);return r===-1?"__local":s[(r+1)%s.length]??"__local"}function Fk(t,e){if(e.length===0)return!0;let n=e.toLowerCase(),s=[He(t.sessionId),t.upstreamSessionId??"",t.agentId??"",t.title??"",t.cwd,Be(t.cwd)];for(let r of s)if(r.toLowerCase().includes(n))return!0;return!1}var Cc,ya,Tk,ah,Ek,Pk,dh=V(()=>{"use strict";Jo();ue();Yt();qo();oo();oc();Ic();Ac();fc();us();Jd();Cc=2,ya=4,Tk=4,ah=4,Ek=20,Pk=[["Composer","type prompt for new session; Enter creates + submits"],["\u2193 from composer","drop focus into session list"],null,["\u2191 / \u2193, n / p, ^p / ^n","navigate sessions"],["PgUp / PgDn","page up / page down"],["Home / End","first / last"],["Enter","open selected session"],["v","view-only (open transcript without spawning the agent)"],null,["/","search sessions (metadata)"],["^f","find in session history (content + tool inputs)"],["o","toggle cwd-only filter"],["h","cycle host filter (local / <peer> / all)"],["i","show info for the selected session"],["I","toggle include-cat filter"],["r","refresh from daemon"],["s","sync sessions from installed agents"],null,["k","kill the selected live session"],["d","delete the selected session (kills first if live)"],["t","retitle the selected session"],["T","regenerate title + synopsis via agent (live session)"],["*","toggle high priority on the selected session (floats to top)"],null,["?","toggle this help"],["q / Esc / ^C / ^D","quit picker (detach)"]]});function wi(t){if(t.length===0)return"";let e=t[0]??"";for(let n=1;n<t.length;n++){let s=t[n]??"",r=0;for(;r<e.length&&r<s.length&&e[r]===s[r];)r+=1;if(e=e.slice(0,r),e.length===0)break}return e}function ch(t){let{matches:e,firstLine:n}=t;if(e.length===0)return null;let s=n.indexOf(" "),r=s===-1?n:n.slice(0,s),i=s===-1?"":n.slice(s);if(e.length===1){let a=e[0]??"",d=i.startsWith(" ")?"":" ";return a+d+i}let o=wi(e);return o.length<=r.length?null:o+i}var wa=V(()=>{"use strict"});import*as lh from"os";async function bi(t,e,n={}){let s=n.defaultCwd??await _m(e.cwd)??lh.homedir();Ir();let r=He(e.sessionId),i=Be(e.cwd),o=n.title??"Fork locally \u2014 choose cwd",a=n.intro??"Pick a local cwd for this session:",d=[{label:"session: ",value:r},...e.importedFromMachine?[{label:"from: ",value:e.importedFromMachine}]:[],{label:"cwd: ",value:i}],c=s,l=null,f=!1,u=null,p=()=>{let v=d.length+6;u=ws(t,{contentHeight:v,title:o});let b=u.contentW,x=0;for(let C of d)t.moveTo(u.contentX,u.contentY+x),t.dim.noFormat(` ${C.label}`),t.noFormat(Mc(C.value,b-C.label.length-2)),x++;x++,t.moveTo(u.contentX,u.contentY+x),t.noFormat(` ${a}`),x+=2,h(x),x+=2,l!==null?(t.moveTo(u.contentX,u.contentY+x),t.red.noFormat(` ${Mc(l,b-2)}`)):(t.moveTo(u.contentX,u.contentY+x),t.dim.noFormat(" Enter accept \xB7 Tab complete \xB7 Esc back \xB7 ^U clear"))},g=()=>d.length+3,h=v=>{if(!u)return;let b=v??g();t.moveTo(u.contentX,u.contentY+b).eraseLineAfter(),t.moveTo(u.x+u.w-1,u.contentY+b),t.dim.noFormat("\u2502"),t.moveTo(u.contentX,u.contentY+b),t.bold.noFormat(" cwd: ");let x=u.contentW-6-2;t.noFormat(Ok(c,x)),f||t.bgWhite(" ")},w=()=>{if(h(),!u)return;let v=g()+2;t.moveTo(u.contentX,u.contentY+v).eraseLineAfter(),t.moveTo(u.x+u.w-1,u.contentY+v),t.dim.noFormat("\u2502"),t.moveTo(u.contentX,u.contentY+v),l!==null?t.red.noFormat(` ${Mc(l,u.contentW-2)}`):t.dim.noFormat(" Enter accept \xB7 Tab complete \xB7 Esc back \xB7 ^U clear")};return p(),await new Promise(v=>{let b=!1,x=()=>{b||(b=!0,t.off("key",q),t.off("resize",O),t.grabInput(!1),t.hideCursor(!1),t.moveTo(1,1).eraseDisplayBelow())},C=W=>{x(),v(W)},O=()=>{b||p()},q=(W,Q,N)=>{if(!f){if(W==="ENTER"||W==="KP_ENTER"){let F=c;f=!0,l=null,w(),pi(F).then(U=>{if(f=!1,U.ok){C({kind:"ok",path:U.path});return}l=U.reason,w()});return}if(W==="ESCAPE"){C({kind:"back"});return}if(W==="CTRL_C"||W==="CTRL_D"){C({kind:"cancel"});return}if(W==="TAB"){f=!0,Fm(c).then(F=>{if(f=!1,F.matches.length===0)return;let U;if(F.matches.length===1)U=F.prefix+F.matches[0];else{let J=wi(F.matches);if(J.length<=F.basePrefix.length)return;U=F.prefix+J}U!==c&&(c=U,l=null,w())});return}if(W==="BACKSPACE"){c.length>0&&(c=c.slice(0,-1),l=null,w());return}if(W==="CTRL_U"){c="",l=null,w();return}if(W==="CTRL_W"){let F=c.replace(/[/\s]+$/,""),U=Math.max(F.lastIndexOf("/"),F.lastIndexOf(" "));c=U>=0?F.slice(0,U+1):"",l=null,w();return}if(N?.isCharacter){c+=W,l=null,w();return}}};t.grabInput({}),t.on("key",q),t.on("resize",O)})}function Mc(t,e){return e<=1?"":t.length<=e?t:t.slice(0,Math.max(0,e-1))+"\u2026"}function Ok(t,e){return e<=1?"":t.length<=e?t:"\u2026"+t.slice(t.length-(e-1))}var uh=V(()=>{"use strict";ue();Yt();rc();wa();ga()});function Dk(t){let e=t.findIndex(n=>n.id===Lk);return e===-1?0:e}async function ph(t,e){Ir();let n=Dk(e),s=0,r=()=>{let a=kc(t)-8;return Math.max(1,Math.min(Bk,e.length,a))},i=()=>{let a=r();n<s?s=n:n>=s+a&&(s=n-a+1);let d=Math.max(0,e.length-a);s>d&&(s=d),s<0&&(s=0)},o=()=>{i();let a=r(),d=a+4,c=Math.min(Nk,Math.max(40,Sc(t)-8)),l=ws(t,{contentHeight:d,contentWidth:c,title:"Select agent"}),f=l.contentW,u=0;t.moveTo(l.contentX,l.contentY+u),t.noFormat(" Which agent should this session use?"),u+=2;let p=Math.min(e.length,s+a);for(let h=s;h<p;h++){let w=e[h];if(!w)continue;let v=h===n?"\u276F":" ",b=w.description??w.name,x=` ${v} ${w.id}`;if(t.moveTo(l.contentX,l.contentY+u),h===n){let C=`${x} ${b}`;t.brightWhite.bgBlue.noFormat(Hk(fh(C,f),f))}else{t.noFormat(x);let C=f-x.length-2;C>1&&t.dim.noFormat(` ${fh(b,C)}`)}u++}u++,t.moveTo(l.contentX,l.contentY+u);let g=e.length>a?` (${n+1}/${e.length})`:"";return t.dim.noFormat(` \u2191/\u2193 navigate \xB7 Enter this session \xB7 s set default \xB7 Esc back${g}`),l};return o(),t.hideCursor(),await new Promise(a=>{let d=!1,c=()=>{d||(d=!0,t.off("key",g),t.off("resize",f),t.grabInput(!1),t.hideCursor(!1),t.moveTo(1,1).eraseDisplayBelow())},l=h=>{c(),a(h)},f=()=>{d||o()},u=()=>{n<e.length-1&&(n++,o())},p=()=>{n>0&&(n--,o())},g=(h,w,v)=>{if(h==="CTRL_C"||h==="CTRL_D"){l({kind:"cancel"});return}if(h==="ESCAPE"){l({kind:"back"});return}if(h==="ENTER"||h==="KP_ENTER"){let b=e[n];b&&l({kind:"select",agentId:b.id,persist:!1});return}if(h==="UP"||h==="SHIFT_TAB"){p();return}if(h==="DOWN"||h==="TAB"){u();return}if(v?.isCharacter){let b=h.toLowerCase();if(b==="s"){let x=e[n];x&&l({kind:"select",agentId:x.id,persist:!0});return}if(b==="j"){u();return}if(b==="k"){p();return}}};t.grabInput({}),t.on("key",g),t.on("resize",f)})}function fh(t,e){return e<=1?"":t.length<=e?t:t.slice(0,Math.max(0,e-1))+"\u2026"}function Hk(t,e){return t.length>=e?t.slice(0,e):t+" ".repeat(e-t.length)}var Lk,Bk,Nk,mh=V(()=>{"use strict";ga();Lk="opencode",Bk=20,Nk=88});import*as gh from"fs";import*as yh from"os";import*as ba from"path";function wh(t,e){let n=e;for(;n>0;){let s=t[n-1]??"";if(/\s/.test(s)){if(s===" "&&t[n-2]==="\\"){n-=2;continue}break}n-=1}return n===e?null:{token:t.slice(n,e),start:n}}function Uk(t){return t.length===0?!1:t.includes("/")?!0:t==="~"||t==="."||t===".."}function jk(t){return t.replace(/\\ /g," ")}function hh(t){return t.replace(/ /g,"\\ ")}function qk(t){let e=t.lastIndexOf("/");return e===-1?{dirPrefix:"",base:t}:{dirPrefix:t.slice(0,e+1),base:t.slice(e+1)}}function Wk(t,e){let n=t.length===0?".":t;return(n==="~"||n.startsWith("~/"))&&(n=yh.homedir()+n.slice(1)),ba.isAbsolute(n)?n:ba.resolve(e,n)}function zk(t){let e;try{e=gh.readdirSync(t,{withFileTypes:!0})}catch{return null}return e.map(n=>({name:n.name,isDir:n.isDirectory()}))}function bh(t,e,n=zk){if(!Uk(t))return null;let s=jk(t),{dirPrefix:r,base:i}=qk(s),o=Wk(r,e),a=n(o);if(a===null)return null;let d=i.startsWith("."),c=a.filter(u=>u.name.startsWith(i)&&(d||!u.name.startsWith(".")));if(c.length===0)return null;let l=c.map(u=>u.isDir?u.name+"/":u.name);if(c.length===1){let u=c[0],p=u.isDir?u.name+"/":u.name;return{replacement:hh(r+p),candidates:l}}let f=wi(c.map(u=>u.name));return{replacement:hh(r+f),candidates:l}}var vh=V(()=>{"use strict";wa()});function Ih(t){let e={};if(!t||typeof t!="object")return e;let n=t;typeof n.historyPolicy=="string"&&(e.appliedPolicy=n.historyPolicy),typeof n.clientId=="string"&&n.clientId.length>0&&(e.clientId=n.clientId);let s=n._meta;if(s&&typeof s=="object"){let r=s["hydra-acp"];if(r&&typeof r=="object"){let i=r.turnStartedAt;typeof i=="number"&&(e.turnStartedAt=i)}}return e}function Sh(t){return!t.replayDraining&&!t.amended&&t.pendingTurns>0&&t.queueSize===0&&!t.ownTurnInFlight&&!t.hasInFlightHead}function kh(t){return t.daemonTurnStartedAt!==void 0?{pendingTurnsDelta:t.pendingTurns===0?1:0,banner:"busy",busySince:t.daemonTurnStartedAt}:{pendingTurnsDelta:t.pendingTurns>0?-t.pendingTurns:0,banner:"ready"}}var xh=V(()=>{"use strict"});import{appendFileSync as Jk,statSync as Kk,renameSync as Vk}from"fs";import{nanoid as Ah}from"nanoid";import Yk from"terminal-kit";import Qk from"fs/promises";import $c from"path";function Ch(t){if(!Array.isArray(t))return;let e=ps({sessionUpdate:"config_option_update",configOptions:t});return e&&e.kind==="config-options"?e.options:void 0}function Rh(t){switch(t.type){case"send":case"amend":case"queue-edit":case"queue-remove":case"plan-toggle":case"attachment-request":return!0;default:return!1}}async function Ph(t){let e=await Z(),n=t.target??await Wt(e);_h=e.tui.logMaxBytes,n.isLocal&&!t.target&&await ir(e);let s=Yk.terminal;sh(s);let r={},i={showThoughts:e.tui.showThoughts,toolsExpanded:!1,planExpanded:!1,showFileUpdates:e.tui.showFileUpdates,mouseEnabled:e.tui.mouse,inAppSelectionEnabled:al(e),defaultEnterAction:e.tui.defaultEnterAction},o=Ec(),a=!1,d=()=>{a||(s.fullscreen(!0),a=!0)},c=()=>{a&&(s.fullscreen(!1),a=!1,process.stdout.write(`
|
|
209
|
+
`))};d();let l=()=>{a&&(s.fullscreen(!1),a=!1)};process.once("exit",l);let f=t;try{for(;f!==null;)f=await Zk(s,e,n,f,r,i,o)}finally{c(),process.off("exit",l)}let u=await li();if(u&&process.stderr.write(`\u2728 ${ui(u)}
|
|
190
210
|
`),process.stdout.isTTY){let p=await Do(e);if(p?.version!==void 0){let g=p.version!==me,h=er(e),w=p.configDigest!==void 0&&p.configDigest!==h;if(g||w){let v=g?`daemon ${p.version} \u2260 cli ${me}`:"config changed since daemon started",b=x=>`\x1B[33m${x}\x1B[0m`;process.stderr.write(b(`! ${v} \u2014 run \`${Pn()} daemon restart\` to apply.`)+`
|
|
191
211
|
`)}}}if(r.sessionId&&process.stdout.isTTY){let p=He(r.sessionId),g=r.readonly?" --readonly":"";process.stdout.write(`Continue: ${Pn()} --session ${p}${g}
|
|
192
|
-
`)}}async function Xk(t,e,n,s,r,i,o){let a=await Zk(t,e,n,s,o);if(!a)return t.grabInput(!1),null;let d=a.sessionId==="__new__"?"Starting new session\u2026":"Resuming session\u2026",c=nx(t,d);c.write(d);let l=n.wsUrl,f=["acp.v1",`hydra-acp-token.${n.token}`],u=null,p=null,g=new yr({url:l,subprotocols:f,onConnect:async m=>{m||u&&await u()},onDisconnect:m=>{p&&p(m)},log:()=>{}}),h=new Kt(g);await g.start(),h.onNotification(Ki,m=>{let y=su.safeParse(m);y.success&&c.applyProgress(y.data)});let w=[],v=null,b=!1,x=!1,C=m=>{m&&(v?v(m):w.push(m))},O,q=m=>{m!==O&&(O=m,m!==void 0&&S.appendLines([{prefix:" ",body:`\u2500\u2500 T${m} \u2500\u2500`,bodyStyle:"dim"}]))},W=0,Q=!1,N,F=null,U=null,J=null,ie=!1,be=m=>{let y=W;W=Math.max(0,W+m);let I=typeof te<"u"&&te!==null;y===0&&W>0?(Q=!1,F=Date.now(),J=Date.now(),X?.setTurnRunning(!0),I&&te.setBanner({status:"busy",elapsedMs:0,stalled:!1}),U===null&&I&&(U=setInterval(()=>{if(F===null||te===null)return;let T=J===null?0:Date.now()-J;te.setBanner({elapsedMs:Date.now()-F,stalled:T>=Qk}),xt()},1e3))):y>0&&W===0?(Q=!1,F=null,J=null,X?.setTurnRunning(!1),U!==null&&(clearInterval(U),U=null),I&&te.setBanner({status:"ready",elapsedMs:void 0,stalled:!1})):W>0&&Q&&(Q=!1,I&&te.setBanner({status:"busy",stalled:!1}))},te=null,X=null,Ie,Y=null,xe=new Set(["session_info_update","current_model_update","current_mode_update","available_commands_update","available_modes_update","usage_update","config_option_update"]),vs=m=>{let{update:y}=m??{},I=fs(y,{cwd:Oe});ex(y,I),J=Date.now();let T=y?.sessionUpdate;if(typeof T=="string"&&!xe.has(T)){let R=y??{};typeof R.messageId=="string"&&(Ie=R.messageId)}if(T==="prompt_received"?be(1):I?.kind==="turn-complete"&&be(-1),T==="permission_resolved"){Sr(y);return}C(I),zn(y)};h.onNotification("session/update",m=>{if(!b){if(Y!==null){Y.push(m);return}vs(m)}}),h.onNotification("hydra-acp/session/closed",()=>{if(b)return;W>0&&be(-W),typeof te<"u"&&te!==null&&te.setBanner({status:"cold",elapsedMs:void 0})});let Nt=new Map,Pt=200,lt=0,vt=!1,Wn=4e3;h.onNotification("hydra-acp/prompt_queue/added",m=>{if(b)return;let y=m??{};if(typeof y.messageId!="string")return;if(typeof y._meta?.["hydra-acp"]?.amending=="string"){let T=y.messageId,R=y.prompt,H=setTimeout(()=>{Nt.delete(T),Re.set(T,Ut(T,R)),te&&X&&pt()},Pt);Nt.set(T,H)}else Re.set(y.messageId,Ut(y.messageId,y.prompt)),te&&X&&pt();if(It!==void 0&&y.originator?.clientId===It){let T=ze.shift();T&&(T.messageId=y.messageId,$t.set(y.messageId,T))}}),h.onNotification("hydra-acp/prompt_queue/updated",m=>{if(b)return;let y=m??{};if(typeof y.messageId!="string"||!Re.has(y.messageId))return;Re.set(y.messageId,Ut(y.messageId,y.prompt));let I=$t.get(y.messageId);if(I){let T=Array.isArray(y.prompt)?y.prompt:[],R="",H=[];for(let z of T){if(!z||typeof z!="object")continue;let D=z;D.type==="text"&&typeof D.text=="string"?R+=D.text:D.type==="image"&&typeof D.data=="string"&&typeof D.mimeType=="string"&&H.push({data:D.data,mimeType:D.mimeType,sizeBytes:Math.floor(D.data.length*3/4)})}I.text=R,I.attachments=H}te&&X&&pt()}),h.onNotification("hydra-acp/prompt_queue/removed",m=>{if(b)return;let y=m??{};if(typeof y.messageId!="string")return;y.reason==="started"&&(N=y.messageId);let I=Nt.get(y.messageId);I!==void 0&&(clearTimeout(I),Nt.delete(y.messageId)),Re.delete(y.messageId)&&te&&X&&pt();let R=$t.get(y.messageId);R&&($t.delete(y.messageId),y.reason==="started"&&(R.flushed=!0,C({kind:"user-text",text:R.displayText,attachments:R.attachments}),ft=R))}),h.onNotification("hydra-acp/cancel_failed",m=>{if(b)return;let y=m??{};if(!(typeof te<"u"&&te!==null))return;lt=Date.now(),vt=!0;let T=typeof y.code=="number"?` (${y.code})`:"",R=typeof y.message=="string"&&y.message.length>0?`: ${y.message}`:"";te.appendLines([{prefix:"\u26A0 ",prefixStyle:"tool-status-fail",body:`cancel rejected by agent${T}${R} \u2014 this agent build may not support cancellation. Cancel again to force-stop (restarts the agent).`,bodyStyle:"tool-status-fail"}])}),h.onNotification("hydra-acp/prompt/amended",m=>{if(b)return;let y=m??{};if(typeof y.cancelledMessageId!="string")return;let I=y.cancelledMessageId;kt.add(I),ft!==null&&ft.messageId!==void 0&&ft.messageId===I&&(C({kind:"turn-complete",stopReason:"cancelled",amended:!0}),ft=null,kt.delete(I))});let Sr=m=>{let y=m??{},I=typeof y.toolCallId=="string"?y.toolCallId:void 0,T;y.outcome&&typeof y.outcome=="object"?T=y.outcome:typeof y.chosenOptionId=="string"&&(T={kind:"selected",optionId:y.chosenOptionId}),kr(I,T?{outcome:T}:void 0)},we=null,kr=(m,y)=>{if(!we||we.toolCallId&&m&&we.toolCallId!==m)return;let I=we.resolve;we=null,S.setPermissionPrompt(null),I(y??{outcome:{outcome:"cancelled"}})},zn=m=>{if(!we?.toolCallId)return;let y=m??{};y.sessionUpdate!=="tool_call"&&y.sessionUpdate!=="tool_call_update"||y.toolCallId===we.toolCallId&&(!y.status||y.status==="pending"||kr(y.toolCallId,void 0))},Is=()=>{if(!we){S.setPermissionPrompt(null);return}S.setPermissionPrompt({title:we.title,detail:we.detail,options:we.options.map(m=>({label:m.name})),selectedIndex:we.selectedIndex})},Jn=m=>{if(!we)return;let{options:y,resolve:I}=we;if(we=null,S.setPermissionPrompt(null),m===null){I({outcome:{outcome:"cancelled"}});return}I({outcome:{outcome:"selected",optionId:m}})};h.onRequest("session/request_permission",async m=>{if(b)return{outcome:{outcome:"cancelled"}};if(s.dangerouslySkipPermissions)return hs(m);let y=m??{},T=(Array.isArray(y.options)?y.options:[]).map(se=>({optionId:se.optionId,name:ke(se.name??""),...se.kind!==void 0?{kind:se.kind}:{}})),R=y.toolCall?.title??y.toolCall?.name??"tool",H=ke(R),z=ke(Im(vm(m))),D=y.toolCall?.toolCallId;return T.length===0?(S.appendLines([{prefix:"\u{1F512} ",body:`Permission requested \xB7 ${H} \xB7 (no options offered, cancelling)`,bodyStyle:"tool-status-fail"}]),{outcome:{outcome:"cancelled"}}):new Promise(se=>{we={title:H,detail:z,options:T,selectedIndex:0,resolve:se,toolCallId:D},Is()})}),h.setDefaultHandler(async()=>({error:{code:-32601,message:"method not implemented"}}));let Qe,mn,Ss=!0,xr=!1;try{let m=await h.request("initialize",{protocolVersion:yt,clientCapabilities:{fs:{readTextFile:!1,writeTextFile:!1},terminal:!1},clientInfo:{name:"hydra-acp-tui",version:me}});mn=m?.agentInfo?.name,m?.agentCapabilities?.promptCapabilities?.image===!1&&(Ss=!1),xr=wt(m?._meta??void 0).prompt?.amending===!0}catch{}let Me=a.sessionId,Dt=a.agentId,Oe=a.cwd,hn,It,Kn,Vn,ks,Yn,gn,Qn,yn,fe;if(a.sessionId==="__new__"){let m={};s.agentId&&(m.agentId=s.agentId),s.name&&(m.title=s.name),s.model&&(m.model=s.model);let y=await h.request("session/new",{cwd:a.cwd,...Object.keys(m).length>0?{_meta:{[Ct]:m}}:{}});Me=y.sessionId,r.sessionId=Me,r.readonly=!1;let I=wt(y._meta??void 0);I.clientId&&(It=I.clientId),Qe=I.upstreamSessionId,I.agentId&&(Dt=I.agentId),I.cwd&&(Oe=I.cwd),I.title&&(hn=I.title),Kn=I.currentModel,Vn=I.currentMode,yn=I.currentUsage,fe=I.turnStartedAt,I.availableCommands&&(ks=Ao(I.availableCommands)),I.availableModes&&(Yn=I.availableModes),gn=Ah(y.configOptions),Qn=I.queue}else{let m={};s.readonly===!0&&(m.readonly=!0),e.tui.toolContent==="references"&&(m.toolContent="references"),s.drip===!0&&(m.replayMode="drip",s.dripSpeed!==void 0&&(m.dripSpeed=s.dripSpeed)),a.resumeHint!==void 0&&(m.resume={upstreamSessionId:a.resumeHint.upstreamSessionId,agentId:a.resumeHint.agentId,cwd:a.resumeHint.cwd});let y=await h.request("session/attach",{sessionId:a.sessionId,historyPolicy:"full",clientInfo:{name:"hydra-acp-tui",version:me},...Object.keys(m).length>0?{_meta:{[Ct]:m}}:{}});Me=y.sessionId,y.clientId&&(It=y.clientId),r.sessionId=Me,r.readonly=s.readonly===!0;let I=wt(y._meta??void 0);Qe=I.upstreamSessionId,I.agentId&&(Dt=I.agentId),I.cwd&&(Oe=I.cwd),I.title&&(hn=I.title),Kn=I.currentModel,Vn=I.currentMode,yn=I.currentUsage,fe=I.turnStartedAt,I.availableCommands&&(ks=Ao(I.availableCommands)),I.availableModes&&(Yn=I.availableModes),gn=Ah(y.configOptions),Qn=I.queue}let Zt=P.tuiHistoryFile(Me),vi=P.globalTuiHistoryFile(),Ge=await zr(Zt).catch(()=>[]),St=await zr(vi).catch(()=>[]);St.length>e.tui.promptHistoryMaxEntries&&(St=St.slice(St.length-e.tui.promptHistoryMaxEntries));let Ht=[...Ge],ae=new un({history:io(St,Ht)});X=ae;let We=!1,wn=(m,y)=>{let I=m.replace(/\n+$/,"");if(I.length===0)return;let T=(y??m).replace(/\n+$/,""),R=Jr(Ge,I),H=R!==Ge;Ge=R,Ht=Jr(Ht,T);let z=Jr(St,I,e.tui.promptHistoryMaxEntries),D=z!==St;St=z,ae.setHistory(io(St,Ht)),H&&cs(Zt,Ge).catch(()=>{}),D&&Hu(vi,I).catch(()=>{})};W>0&&ae.setTurnRunning(!0);let Ee=null,xs=null;eh(e.tui.ambiguousWidth==="wide"),Pp(e.tui.diffContextLines);let Le=!1,S,Ar=()=>{Le&&(Le=!1,S.start())},Ii=()=>{Le||(Le=!0,S.stop(),process.kill(process.pid,"SIGTSTP"))};process.platform!=="win32"&&process.on("SIGCONT",Ar),S=new pa({term:t,dispatcher:ae,repaintThrottleMs:e.tui.repaintThrottleMs,maxScrollbackLines:e.tui.maxScrollbackLines,mouse:i.mouseEnabled,inAppSelection:i.inAppSelectionEnabled,selectionClipboard:e.tui.selectionClipboard,progressIndicator:e.tui.progressIndicator,readonly:s.readonly===!0,onSuspend:process.platform!=="win32"?Ii:void 0,onBlockClick:m=>{Xh(m)},onBlockVisible:m=>{Qh(m)},onMouse:m=>{if(m.kind!=="press"||m.button!=="middle")return;let y={type:"attachment-request",source:"primary"};s.readonly===!0&&Ch(y)||Ae(y)},onKey:m=>{for(let y of m){if(we&&tn(y)||va(y)||M(y)||As(y)||Er(y))continue;if(y.type==="attachment-paths"){Mt(y.paths);continue}let I=ae.feed(y);for(let T of I)s.readonly===!0&&Ch(T)||Ae(T)}Tr(),S.setBannerSearchIndicator(ae.state().historySearchQuery),S.setAttachments(ae.state().attachments),S.refreshPrompt()}}),te=S,S.setStickyBottomKey("plan");let bn=[{name:"/help",description:"Show TUI built-in commands"},{name:"/quit",description:"Exit the TUI"},{name:"/clear",description:"Clear scrollback"},{name:"/sessions",description:"List sessions"},{name:"/resume",description:"Switch sessions (open the picker)"},{name:"/rename",description:"Rename this session (alias for /hydra title): /rename [title]"},{name:"/model",description:"Switch model: /model <model-id>"},{name:"/agent",description:"Switch agent via config option: /agent <agent-id>"},{name:"/demo-plan",description:"Inject synthetic plan events (UI test)"},{name:"/demo-tool",description:"Inject a synthetic tool-call sequence (UI test)"}],vn=ks??[],en=Yn??[],In=gn??[],Gn=()=>In.find(m=>m.id==="agent"),Cr=()=>{let m=new Set,y=[];for(let I of[...bn,...vn])m.has(I.name)||(m.add(I.name),y.push(I));return y},Rr=()=>{let m=ae.state().buffer,y=m[0]??"";if(!y.startsWith("/"))return[];if(m.length>1)return[];let I=y.indexOf(" "),T=I===-1?y:y.slice(0,I);if(T.lastIndexOf("/")>0)return[];let R=Cr().filter(H=>H.name.startsWith(T));return R.length===1&&R[0]?.name===T&&I===-1?[]:R},Sn=[],Tr=()=>{let m=Rr();if(m.length>0){Sn=[],S.setCompletions(m);return}S.setCompletions(Sn)},Er=m=>{if(m.type!=="key"||m.name!=="tab")return Sn.length>0&&(Sn=[]),!1;let y=Rr();if(y.length>0){Sn=[];let I=ae.state().buffer[0]??"",T=dh({matches:y.map(R=>R.name),firstLine:I});return T===null||ae.replaceFirstLine(T),!0}return Pr()},Pr=()=>{let m=ae.state(),y=m.buffer[m.row]??"",I=yh(y,m.col);if(I===null)return!1;let T=wh(I.token,Oe);return T===null?!1:(T.replacement!==I.token&&ae.replaceRangeOnCurrentLine(I.start,m.col,T.replacement),Sn=T.candidates.length>1?T.candidates.map(R=>({name:R})):[],!0)},As=m=>{if(!S.isScrollbackSearchActive())return m.type==="key"&&m.name==="ctrl-r"&&S.isScrolledBack()?(S.enterScrollbackSearch(),S.updateScrollbackSearchTerm(""),!0):!1;if(m.type==="char"){let y=S.scrollbackSearchTerm()+m.ch;return S.updateScrollbackSearchTerm(y),!0}if(m.type==="paste"){let y=S.scrollbackSearchTerm()+m.text.replace(/\n/g," ");return S.updateScrollbackSearchTerm(y),!0}if(m.type==="key")switch(m.name){case"ctrl-r":return S.advanceScrollbackSearch(),!0;case"ctrl-s":return S.retreatScrollbackSearch(),!0;case"backspace":{let y=S.scrollbackSearchTerm();return y.length===0?S.cancelScrollbackSearch():S.updateScrollbackSearchTerm(y.slice(0,-1)),!0}case"enter":return S.acceptScrollbackSearch(),!0;case"escape":case"ctrl-c":return S.cancelScrollbackSearch(),!0;default:return!0}return!0},tn=m=>{if(!we)return!1;let y=we.options;if(m.type==="key")switch(m.name){case"up":return we.selectedIndex=Math.max(0,we.selectedIndex-1),Is(),!0;case"down":return we.selectedIndex=Math.min(y.length-1,we.selectedIndex+1),Is(),!0;case"enter":{let I=y[we.selectedIndex];return I&&Jn(I.optionId),!0}case"escape":case"ctrl-c":return Jn(null),!0;default:return!0}if(m.type==="char"&&/^[1-9]$/.test(m.ch)){let I=parseInt(m.ch,10)-1,T=y[I];return T&&Jn(T.optionId),!0}return!0},kn=Dt||mn||"?",nt={...yn??{}};c.finalize(),S.start({skipFullscreen:!0}),S.setHideThoughts(!i.showThoughts),S.setSessionbar({agent:kn,cwd:Oe,sessionId:Me,title:hn,model:Kn,usage:{...nt}}),Vn&&S.setBanner({currentMode:Vn}),li().then(m=>{m&&S.notify(`\u2728 ${ui(m)}`,3e4)});let ut=null,Si=new Promise(m=>{ut=m}),ki=()=>{h.notify("session/cancel",{sessionId:Me}).catch(()=>{})},Mr=()=>{te!==null&&W===1&&(Q=!0,te.setBanner({status:"cancelling",elapsedMs:void 0,stalled:!1}))},xn=()=>{if(Ee){Ee.cancel(),Mr();return}if(W>0){ki(),Mr();return}$r()},$r=()=>{K(0)},xi=()=>{let m="enqueue prompt (sends now, or queues during a turn)",y="amend the in-flight turn (cancel + replace)";return[...i.defaultEnterAction==="amend"?[["Enter",y],["Ctrl+Enter / Shift+Enter / ^S",m]]:[["Enter",m],["Ctrl+Enter / Shift+Enter / ^S",y]],...Gk]},Lc=()=>{if(S.isHelpPromptActive()){S.setHelpPrompt(null);return}S.setHelpPrompt({title:"Hotkeys",entries:xi(),hint:"any key dismisses \xB7 /help lists commands"})},va=m=>S.isHelpPromptActive()?(m.type==="key"&&m.name==="ctrl-g",S.setHelpPrompt(null),!0):!1,Xn=["tools","plan","thoughts","diffs","mouse","enter"],Xe=0,nn=m=>{switch(m){case"tools":return i.toolsExpanded?"expanded":"collapsed";case"plan":return i.planExpanded?"expanded":"collapsed";case"thoughts":return i.showThoughts?"shown":"hidden";case"diffs":return i.showFileUpdates;case"mouse":return i.mouseEnabled?"on":"off";case"enter":return i.defaultEnterAction}},st=m=>{switch(m){case"tools":return"Tools";case"plan":return"Plan";case"thoughts":return"Thoughts";case"diffs":return"File updates";case"mouse":return"Mouse capture";case"enter":return"Enter key"}},Cs=()=>({title:"Session options",options:Xn.map(m=>({label:st(m),value:nn(m)})),selectedIndex:Xe}),Rs=()=>{S.isOptionsPromptActive()&&S.setOptionsPrompt(Cs())},Ai=()=>{if(S.isOptionsPromptActive()){S.setOptionsPrompt(null);return}Xe=0,S.setOptionsPrompt(Cs())},Zn=m=>{switch(m){case"tools":i.toolsExpanded=!i.toolsExpanded,E.clear(),Vh();break;case"plan":i.planExpanded=!i.planExpanded,Ze=null,Rn();break;case"thoughts":i.showThoughts=!i.showThoughts,S.setHideThoughts(!i.showThoughts);break;case"diffs":i.showFileUpdates=i.showFileUpdates==="diff"?"edit":"diff",sn.clear(),Gh();break;case"mouse":{let y=!S.isMouseEnabled();S.setMouseEnabled(y),i.mouseEnabled=y;break}case"enter":i.defaultEnterAction=i.defaultEnterAction==="amend"?"enqueue":"amend";break}Rs()},k=m=>{(async()=>{try{switch(m){case"tools":case"plan":S.notify(`${st(m)} is session-only \u2014 not saved`);return;case"thoughts":await Lr("showThoughts",i.showThoughts);break;case"diffs":await Lr("showFileUpdates",i.showFileUpdates);break;case"mouse":await Lr("mouse",i.mouseEnabled);break;case"enter":await Lr("defaultEnterAction",i.defaultEnterAction);break}S.notify(`saved default: ${st(m)} ${nn(m)}`)}catch(y){S.notify(`save failed: ${y instanceof Error?y.message:String(y)}`)}})()},M=m=>{if(!S.isOptionsPromptActive())return!1;if(m.type==="key")switch(m.name){case"up":return Xe=Math.max(0,Xe-1),Rs(),!0;case"down":return Xe=Math.min(Xn.length-1,Xe+1),Rs(),!0;case"enter":{let y=Xn[Xe];return y&&Zn(y),!0}case"ctrl-o":case"escape":case"ctrl-c":return S.setOptionsPrompt(null),!0;case"ctrl-d":return S.setOptionsPrompt(null),!1;default:return!0}if(m.type==="char"){if(/^[1-9]$/.test(m.ch)){let y=parseInt(m.ch,10)-1,I=Xn[y];return I&&(Xe=y,Zn(I)),!0}if(m.ch==="s"||m.ch==="S"){let y=Xn[Xe];return y&&k(y),!0}}return!0},_=()=>{b=!0,process.off("SIGINT",xn),process.platform!=="win32"&&process.off("SIGCONT",Ar),U!==null&&(clearInterval(U),U=null),S.clearWindowTitle(),S.stop({keepFullscreen:!0}),cs(Zt,Ge).catch(()=>{}),g.close().catch(()=>{})},K=(m=0)=>{_(),ut&&(ut(null),ut=null),m!==0&&process.exit(m)},ce=async()=>{if(!ut)return;let m=ae.state().buffer.join(`
|
|
193
|
-
`);m.replace(/\s+$/,"").length>0&&wn(m),S.pauseRepaint(),S.stop({keepFullscreen:!0}),
|
|
194
|
-
`))return!1;let I=y.indexOf(" ");switch(I===-1?y:y.slice(0,I)){case"/quit":case"/exit":return $r(),!0;case"/clear":return Te.clear(),Cn.clear(),rn.length=0,$=null,ee=null,G=null,An.clear(),sn.clear(),ss.clear(),E.clear(),j.clear(),oe.clear(),S.clearScrollback(),!0;case"/demo-plan":{S.clearKey("plan");let R=["Step 1","Step 2","Step 3","Step 4","Step 5"],H=[["pending","pending","pending","pending","pending"],["in_progress","pending","pending","pending","pending"],["completed","in_progress","pending","pending","pending"],["completed","completed","in_progress","pending","pending"],["completed","completed","completed","in_progress","pending"],["completed","completed","completed","completed","in_progress"],["completed","completed","completed","completed","completed"]],z=0,D=()=>{let se=H[z];se&&(C({kind:"plan",entries:R.map((Ce,Se)=>({content:Ce,status:se[Se]??"pending"}))}),z+=1,setTimeout(D,600))};return D(),!0}case"/demo-tool":{let R=`demo-${Date.now()}`;return C({kind:"tool-call",toolCallId:R,title:"Terminal",status:"pending"}),setTimeout(()=>{C({kind:"tool-call-update",toolCallId:R,title:"echo hello world",status:"in_progress"})},500),setTimeout(()=>{C({kind:"tool-call-update",toolCallId:R,status:"completed"})},1500),!0}case"/help":{let R=[{prefix:" ",body:"Built-in commands:",bodyStyle:"system"}];for(let H of bn)R.push({prefix:" ",body:` ${H.name.padEnd(12)} ${H.description??""}`,bodyStyle:"info"});if(vn.length>0){R.push({prefix:" ",body:"Agent commands:",bodyStyle:"system"});for(let H of vn)R.push({prefix:" ",body:` ${H.name.padEnd(12)} ${H.description??""}`,bodyStyle:"info"})}return S.appendLines(R),!0}case"/agent":{let R=I===-1?"":y.slice(I+1).trim(),H=Gn();if(!H)return S.appendLines([{prefix:" ",body:"no agent config option advertised for this session",bodyStyle:"info"}]),!0;if(!R){let z=[{prefix:" ",body:"Available agents:",bodyStyle:"system"}];for(let D of H.options){let se=D.value===H.currentValue?"* ":" ";z.push({prefix:" ",body:`${se}${D.value.padEnd(16)} ${D.name}`,bodyStyle:"info"})}return S.appendLines(z),!0}return H.options.some(z=>z.value===R)?R===H.currentValue?(S.notify(`already on agent ${R}`),!0):(S.notify(`switching to ${R}\u2026`),h.request("session/set_config_option",{sessionId:Me,configId:"agent",value:R}).catch(z=>{S.notify(`set_config_option failed: ${z.message}`)}),!0):(S.notify(`unknown agent: ${R}`),!0)}case"/sessions":return S.appendLines([{prefix:" ",body:"Run `hydra-acp sessions` (or `hydra sessions`) for the full list.",bodyStyle:"info"}]),!0;case"/resume":return ce(),!0;case"/rename":{let R=I===-1?"":y.slice(I+1).trim(),H=R.length>0?`/hydra title ${R}`:"/hydra title";return wn(y,y),Fr(H,[],y),!0}default:return!1}},Fr=async(m,y,I)=>{let T=[];m.length>0&&T.push({type:"text",text:m});for(let Se of y)T.push({type:"image",data:Se.data,mimeType:Se.mimeType});be(1);let R={text:m,displayText:I??m,attachments:y,flushed:!1};ze.push(R),vt=!1;let H=!1,z=null,D=Se=>{typeof te<"u"&&te!==null&&te.appendLines([{prefix:"\u26A0 ",prefixStyle:"tool-status-fail",body:Se,bodyStyle:"tool-status-fail"}])},se=!1;Ee={text:m,attachments:y,cancel:()=>{if(vt){vt=!1,se=!0,D("force-stopping agent \u2014 turn aborted; resumes on your next message\u2026"),h.request("hydra-acp/session/force_cancel",{sessionId:Me}).catch(De=>{D(`force-stop failed: ${De.message}`)});return}if(H)return;H=!0,h.notify("session/cancel",{sessionId:Me}).catch(()=>{});let Se=Date.now();z=setTimeout(()=>{Ee!==null&&(lt>=Se||(vt=!0,D("cancel not acknowledged by agent \u2014 the turn is still running. Cancel again to force-stop (restarts the agent).")))},Wn)}};let Ce;try{let Se=await h.request("session/prompt",{sessionId:Me,prompt:T});Se&&typeof Se.stopReason=="string"&&(Ce=Se.stopReason)}catch(Se){let De=ze.indexOf(R);De>=0&&ze.splice(De,1),R.messageId!==void 0&&$t.delete(R.messageId),se?S.appendLines([{prefix:"\u26A0 ",prefixStyle:"tool-status-fail",body:"turn force-stopped",bodyStyle:"tool-status-fail"}]):S.appendLines([{prefix:"\u2717 ",prefixStyle:"tool-status-fail",body:Se.message,bodyStyle:"tool-status-fail"}])}finally{if(Ee=null,z!==null&&(clearTimeout(z),z=null),be(-1),R.flushed&&ft===R){let Se=R.messageId!==void 0&&kt.has(R.messageId);Se&&R.messageId!==void 0&&kt.delete(R.messageId);let De={kind:"turn-complete"};Ce!==void 0&&(De.stopReason=Ce),Se&&(De.amended=!0),C(De),ft=null}if(xs!==null){let{text:Se,attachments:De}=xs;xs=null,ae.state().buffer.every(at=>at==="")&&(ae.setBuffer(Se,De),S.refreshPrompt())}}},Te=new Map,An=new Map,sn=new Map,Cn=new Map,rn=[],ns=0,jt=`tools:${ns}`,ss=new Map,E=new Map,j=new Map,oe=new Map,$=null,ee=null,G=null,le=null,Ze=null,Je=e.tui.maxToolItems,_t=e.tui.maxPlanItems,$e=()=>({maxPlanItems:Ze??i.planExpanded?1/0:_t}),Rn=()=>{if(le===null)return;let m=pr(le,$e());m.length>0&&S.upsertLines("plan",[{body:""},...m])},Es="",Ps=null,Bc=0,jh=()=>{if(Ps===null)return;let m=S.width(),y=mr(Es,m>0?{maxWidth:m}:void 0);y.length!==0&&S.upsertLines(Ps,y)},qh=m=>{m.length!==0&&(Ps===null&&(S.ensureSeparator(),Ps=`agent:${Bc}`,Bc+=1,Es=""),Es+=m,jh())},Tn=()=>{Ps=null,Es=""},Ms="",rs=null,Nc=0,Wh=()=>({prefix:" ",body:"\u25B8 Thoughts",bodyStyle:"thought"}),zh=()=>{if(rs===null||Ms.length===0)return;let m=Nd(Ms);m.length!==0&&S.upsertLines(rs,m)},Jh=m=>{let y=j.get(m);if(y===void 0)return[];let I=Nd(y.text);return y.workerTaskId&&I.unshift({prefix:" ",body:`[T${y.workerTaskId}] `,bodyStyle:"dim"}),I},Kh=(m,y)=>{m.length!==0&&(rs===null&&(S.ensureSeparator("thought"),rs=`thought:${Nc}`,Nc+=1,Ms=""),Ms+=m,j.set(rs,{text:Ms,workerTaskId:y}),zh())},En=()=>{rs=null,Ms=""},Dc=m=>{let{order:y,states:I,startedAt:T,endedAt:R,stopReason:H}=m,z=y.length,D=Je>0,se=!D||m.expanded?y:y.slice(Math.max(0,z-Je)),Ce=z-se.length,Se=R===null,De=R??Date.now(),Ke=De-T,at=!Se&&H!==null&&H!=="end_turn"?H:null,Vc=at==="amended",Yc=Vc?`amended \xB7 ${Gt(Ke)}`:`stopped (${at}) \xB7 ${Gt(Ke)}`,Mi;if(z===0)at!==null?Mi=Yc:Mi=Se?`thinking \xB7 ${Gt(Ke)}`:`thought \xB7 ${Gt(Ke)}`;else{let ka=z===1?"tool":"tools",$i=at!==null?Yc:Se?Gt(Ke):`took ${Gt(Ke)}`,Zc=[`${z} ${ka}`,$i];Se&&D&&Ce>0&&Zc.push(`${Ce} hidden`),Mi=Zc.join(" \xB7 ")}let Qc=z===0&&Se,Gc=Vc?"tool-status-cancelled":"tool-status-fail",Xc=[{prefix:"\u2699 ",prefixStyle:Qc?"tool-status-running":at!==null?Gc:"tool",body:Mi,bodyStyle:Qc?"tool-status-running":at!==null?Gc:"dim"}];for(let ka of se){let $i=I.get(ka);$i&&Xc.push(...Tp($i,De))}return Xc},Hc=m=>E.get(m)??i.toolsExpanded,xt=()=>{if($===null)return;let m=Dc({order:rn,states:Te,startedAt:$,endedAt:ee,stopReason:G,expanded:Hc(jt)});S.upsertLines(jt,m)},Uc=m=>{let y=ss.get(m);if(!y)return;let I=Dc({order:y.order,states:y.states,startedAt:y.startedAt,endedAt:y.endedAt,stopReason:y.stopReason,expanded:Hc(m)});S.upsertLines(m,I)},Vh=()=>{$!==null&&!ss.has(jt)&&xt();for(let m of ss.keys())Uc(m)},Sa=()=>{$!==null&&ss.set(jt,{order:[...rn],states:new Map(Te),startedAt:$,endedAt:ee??Date.now(),stopReason:G})},jc=()=>{ns+=1,jt=`tools:${ns}`,$=Date.now(),ee=null,G=null,xt()},qc=(m,y,I,T,R,H,z)=>{let D=!Te.has(m),se=Te.get(m),Ce=se??{initialTitle:y??"tool",latestTitle:y??"tool",status:I??"pending",startedAt:Date.now()};!se&&z!==void 0&&(Ce.workerTaskId=z),se&&y!==void 0&&(Ce.latestTitle=y),H!==void 0&&Ce.detail===void 0&&(Ce.detail=H),se&&I!==void 0&&(Ce.status=I),se||(Ce.status=I??"pending"),Ce.endedAt===void 0&&_p(Ce.status)&&(Ce.endedAt=Date.now()),T!==void 0&&(Ce.errorText=T),R!==void 0&&(Ce.editDiff=R),Te.set(m,Ce),D&&($===null&&(ns+=1,jt=`tools:${ns}`,$=Date.now(),ee=null,G=null),rn.push(m))},Wc=async m=>{try{let y=await h.request("hydra-acp/session/tool_content",{sessionId:Me,hash:m});return typeof y?.content=="string"?y.content:null}catch{return null}},Ti=new Set,Yh=(m,y)=>{Ti.has(m)||y.oldRef===void 0&&y.newRef===void 0||(Ti.add(m),(async()=>{let[I,T]=await Promise.all([y.oldRef?Wc(y.oldRef.hash):Promise.resolve(y.oldText),y.newRef?Wc(y.newRef.hash):Promise.resolve(y.newText)]);if(y.oldRef!==void 0&&I===null||y.newRef!==void 0&&T===null){Ti.delete(m);let Ce=Dd(y,"diff",{deferredStatus:"error"});Ce.length>0&&(S.upsertLines(`editdiff:${m}`,Ce),S.repaintNow());return}let H={...y.path!==void 0?{path:y.path}:{},oldText:I??"",newText:T??""};An.set(m,H);let z=Te.get(m);z?.editDiff&&(z.editDiff=H),Ti.delete(m);let D=sn.get(m),se=D===void 0?i.showFileUpdates:D?"diff":"edit";se!=="none"&&(Ei(m,H,se==="diff"?"diff":"edit"),S.repaintNow())})())},Ei=(m,y,I)=>{let T=`editdiff:${m}`,R=Dd(y,I);if(R.length===0){S.removeKey(T);return}S.upsertLines(T,R),I==="diff"&&(y.oldRef!==void 0||y.newRef!==void 0)&&S.notifyWhenVisible(T)},Qh=m=>{if(!m.startsWith("editdiff:"))return;let y=m.slice(9),I=An.get(y);I&&(I.oldRef!==void 0||I.newRef!==void 0)&&Yh(y,I)},zc=m=>{let y=`editdiff:${m}`,I=i.showFileUpdates,T=Te.get(m),R;if(I==="none"||!T?.editDiff||T.status!=="completed")R=null;else{let z=sn.get(m);R=z!==void 0?z?"diff":"edit":I==="diff"?"diff":"edit"}if(R===null){S.removeKey(y);return}let H=T.editDiff;An.set(m,H),Ei(m,H,R)},Gh=()=>{let m=i.showFileUpdates;for(let[y,I]of An){let T=`editdiff:${y}`,R=sn.get(y),H=R===void 0?m:R?"diff":"edit";if(H==="none"){S.removeKey(T);continue}Ei(y,I,H==="diff"?"diff":"edit")}},Xh=m=>{if(m.startsWith("editdiff:")){let y=m.slice(9),I=An.get(y);if(!I)return;let T=sn.get(y)??i.showFileUpdates==="diff";sn.set(y,!T),Ei(y,I,T?"edit":"diff"),S.repaintNow();return}if(m==="plan"){if(le===null)return;Ze=!(Ze??i.planExpanded),Rn(),S.repaintNow();return}if(m.startsWith("tools:")){let y=E.get(m)??i.toolsExpanded;E.set(m,!y),m===jt&&$!==null?xt():Uc(m),S.repaintNow();return}if(m.startsWith("thought:")){if(!j.has(m))return;let y=oe.get(m);if(y!==void 0){oe.delete(m),S.setRunCollapsed(y,!1,Jh(m)),S.repaintNow();return}let I=S.contiguousRun(m,new Set(j.keys()));if(I.length===0)return;let T=I[0];oe.set(T,I),S.setRunCollapsed(I,!0,[Wh()]),S.repaintNow();return}};v=m=>{if(m.kind==="available-commands"){vn=m.commands,Tr();return}if(m.kind==="available-modes"){en=m.modes;return}if(m.kind==="config-options"){In=m.options;let I=m.options.find(R=>R.id==="agent");I&&I.currentValue&&I.currentValue!==Dt&&(Dt=I.currentValue,S.setSessionbar({agent:I.currentValue}));let T=m.options.find(R=>R.id==="mode");T&&(en=T.options.map(R=>({id:R.value,name:R.name??R.value,...R.description!==void 0?{description:R.description}:{}})));return}if(m.kind==="mode-changed"){S.setBanner({currentMode:m.mode||void 0});return}if(m.kind==="session-info"){m.title!==void 0&&S.setSessionbar({title:m.title}),m.agentId!==void 0&&m.agentId!==Dt&&(Dt=m.agentId,S.setSessionbar({agent:m.agentId}));return}if(m.kind==="usage-update"){let I=!1;m.used!==void 0&&nt.used!==m.used&&(nt.used=m.used,I=!0),m.size!==void 0&&nt.size!==m.size&&(nt.size=m.size,I=!0),m.costAmount!==void 0&&nt.costAmount!==m.costAmount&&(nt.costAmount=m.costAmount,I=!0),m.costCurrency!==void 0&&nt.costCurrency!==m.costCurrency&&(nt.costCurrency=m.costCurrency,I=!0),I&&S.setSessionbar({usage:{...nt}});return}if(m.kind==="user-text"){We&&wn(m.text),Tn(),En(),$!==null&&(ee=Date.now(),xt()),ft=null,S.ensureSeparator();let I=pr(m);I.length>0&&S.appendLines(I),Sa(),S.clearKey("plan"),le=null,Ze=null,Te.clear(),Cn.clear(),rn.length=0,ee=null,jc(),S.redraw();return}if(m.kind==="agent-text"){En(),Ps===null&&q(m.workerTaskId),qh(m.text);return}if(m.kind==="agent-thought"){Tn(),rs===null&&q(m.workerTaskId),Kh(m.text,m.workerTaskId);return}if(m.kind==="exit-plan-mode"){Tn(),En();let I=Cn.get(m.toolCallId),T={plan:m.plan??I?.plan??"",status:m.status??I?.status};if(Cn.set(m.toolCallId,T),T.plan.length===0)return;let R=Fp(T);R.length>0&&S.upsertLines(m.toolCallId,R);return}if(m.kind==="tool-call"){Tn(),En(),Te.has(m.toolCallId)||q(m.workerTaskId),qc(m.toolCallId,m.title,m.status,void 0,m.editDiff,m.detail,m.workerTaskId),xt(),zc(m.toolCallId);return}if(m.kind==="plan"){Tn(),En(),le=m;let I=pr(m,$e());I.length>0&&S.upsertLines("plan",[{body:""},...I]);let T=m.entries.length>0&&m.entries.every(R=>(R.status??"pending")==="completed");S.setStickyBottomKey(T?null:"plan");return}if(m.kind==="tool-call-update"){Tn(),En(),qc(m.toolCallId,m.title,m.status,m.errorText,m.editDiff,m.detail,m.workerTaskId),m.upstreamInterrupted&&(ie=!0),xt(),zc(m.toolCallId);return}m.kind==="model-changed"&&S.setSessionbar({model:m.model});let y=pr(m);if(y.length>0&&S.appendLines(y),m.kind==="turn-complete"){N=void 0,Tn(),En();let I=m.amended?"amended":m.stopReason;if(!m.amended&&ie&&(I===void 0||I==="end_turn")&&(I="error"),le!==null&&I!==void 0&&I!=="end_turn"){let T=pr({...le,stopped:!0,amended:m.amended===!0},$e());T.length>0&&S.upsertLines("plan",[{body:""},...T])}le=null,Ze=null,S.clearKey("plan"),S.setStickyBottomKey("plan"),$!==null?(ee=Date.now(),G=I??null,xt(),Sa()):I!==void 0&&I!=="end_turn"&&I!=="amended"&&S.appendLines([{prefix:"\u26A0 ",prefixStyle:"tool-status-fail",body:`turn ended: ${I}`,bodyStyle:"tool-status-fail"}]),Te.clear(),Cn.clear(),rn.length=0,$=null,ee=null,G=null,ie=!1,S.ensureSeparator(),Ih({pendingTurns:W,queueSize:Re.size,ownTurnInFlight:Ee!==null,hasInFlightHead:N!==void 0,replayDraining:x,amended:m.amended===!0})&&be(-W)}};let Jc=w;w=[];let Pi=[];for(let m of Jc)m.kind==="user-text"&&typeof m.text=="string"&&Pi.push(m.text);S.pauseRepaint(),x=!0;try{for(let m of Jc)v(m)}finally{x=!1,S.resumeRepaint()}if(Pi.length>0){let m=gd(Ge,Pi);m!==Ge&&(Ge=m,Ht=gd(Ht,Pi),ae.setHistory(io(St,Ht)),cs(Zt,Ge).catch(()=>{}))}We=!0,fe!==void 0&&W>0?(F=fe,S.setBanner({status:"busy",elapsedMs:Date.now()-fe}),U===null&&(U=setInterval(()=>{F===null||te===null||(te.setBanner({elapsedMs:Date.now()-F}),xt())},1e3)),$===null&&jc(),$=fe,xt()):fe===void 0&&W>0&&be(-W);let Zh=()=>{if(we){let m=we.resolve;we=null,S.setPermissionPrompt(null),m({outcome:{outcome:"cancelled"}})}Tn(),En()},Kc=()=>{$!==null&&(ee=Date.now(),G="reconnect-recovery-failed",xt(),Sa(),Te.clear(),Cn.clear(),rn.length=0,$=null,ee=null,G=null)};return p=()=>{S.setBanner({status:"disconnected",elapsedMs:void 0})},u=async()=>{Zh();let m={jsonrpc:"2.0",id:`tui-reinit-${xh()}`,method:"initialize",params:{protocolVersion:yt,clientCapabilities:{fs:{readTextFile:!1,writeTextFile:!1},terminal:!1},clientInfo:{name:"hydra-acp-tui",version:me}}};try{await g.request(m)}catch{}let y=Ie!==void 0,I={jsonrpc:"2.0",id:`tui-reattach-${xh()}`,method:"session/attach",params:{sessionId:Me,historyPolicy:y?"after_message":"none",...y?{afterMessageId:Ie}:{},clientInfo:{name:"hydra-acp-tui",version:me},...(()=>{let D={};return Qe!==void 0&&(D.resume={upstreamSessionId:Qe,agentId:Dt,cwd:Oe}),e.tui.toolContent==="references"&&(D.toolContent="references"),Object.keys(D).length>0?{_meta:{[Ct]:D}}:{}})()}};Y=[];let T,R,H;try{let D=await g.request(I);if(D.error)throw new Error(D.error.message);H=vh(D.result),T=H.appliedPolicy,H.clientId!==void 0&&(It=H.clientId)}catch(D){R=D}let z=Y??[];if(Y=null,R)Kc(),S.appendLines([{prefix:" ",body:`reattach failed: ${R.message}`,bodyStyle:"tool-status-fail"}]);else if(y&&T!=="after_message")Kc(),S.appendLines([{prefix:"\u26A0 ",prefixStyle:"tool-status-fail",body:"reconnect couldn't replay events since last seen \u2014 scrollback may be incomplete",bodyStyle:"tool-status-fail"}]);else{x=!0;try{for(let D of z)vs(D)}finally{x=!1}}if(H){let D=Sh({daemonTurnStartedAt:H.turnStartedAt,pendingTurns:W});D.pendingTurnsDelta!==0&&be(D.pendingTurnsDelta),D.banner==="busy"&&D.busySince!==void 0?(F=D.busySince,S.setBanner({status:"busy",elapsedMs:Date.now()-D.busySince}),U===null&&(U=setInterval(()=>{F===null||te===null||(te.setBanner({elapsedMs:Date.now()-F}),xt())},1e3))):S.setBanner({status:"ready",elapsedMs:void 0})}else S.setBanner({status:W>0?"busy":"ready",elapsedMs:W>0?0:void 0})},h.onClose(m=>{m&&t.red(`
|
|
212
|
+
`)}}async function Zk(t,e,n,s,r,i,o){let a=await ex(t,e,n,s,o);if(!a)return t.grabInput(!1),null;let d=a.sessionId==="__new__"?"Starting new session\u2026":"Resuming session\u2026",c=sx(t,d);c.write(d);let l=n.wsUrl,f=["acp.v1",`hydra-acp-token.${n.token}`],u=null,p=null,g=new yr({url:l,subprotocols:f,onConnect:async m=>{m||u&&await u()},onDisconnect:m=>{p&&p(m)},log:()=>{}}),h=new Kt(g);await g.start(),h.onNotification(Ki,m=>{let y=su.safeParse(m);y.success&&c.applyProgress(y.data)});let w=[],v=null,b=!1,x=!1,C=m=>{m&&(v?v(m):w.push(m))},O,q=m=>{m!==O&&(O=m,m!==void 0&&S.appendLines([{prefix:" ",body:`\u2500\u2500 T${m} \u2500\u2500`,bodyStyle:"dim"}]))},W=0,Q=!1,N,F=null,U=null,J=null,ie=!1,be=m=>{let y=W;W=Math.max(0,W+m);let I=typeof te<"u"&&te!==null;y===0&&W>0?(Q=!1,F=Date.now(),J=Date.now(),X?.setTurnRunning(!0),I&&te.setBanner({status:"busy",elapsedMs:0,stalled:!1}),U===null&&I&&(U=setInterval(()=>{if(F===null||te===null)return;let T=J===null?0:Date.now()-J;te.setBanner({elapsedMs:Date.now()-F,stalled:T>=Gk}),xt()},1e3))):y>0&&W===0?(Q=!1,F=null,J=null,X?.setTurnRunning(!1),U!==null&&(clearInterval(U),U=null),I&&te.setBanner({status:"ready",elapsedMs:void 0,stalled:!1})):W>0&&Q&&(Q=!1,I&&te.setBanner({status:"busy",stalled:!1}))},te=null,X=null,Ie,Y=null,xe=new Set(["session_info_update","current_model_update","current_mode_update","available_commands_update","available_modes_update","usage_update","config_option_update"]),Is=m=>{let{update:y}=m??{},I=ps(y,{cwd:Oe});tx(y,I),J=Date.now();let T=y?.sessionUpdate;if(typeof T=="string"&&!xe.has(T)){let R=y??{};typeof R.messageId=="string"&&(Ie=R.messageId)}if(T==="prompt_received"?be(1):I?.kind==="turn-complete"&&be(-1),T==="permission_resolved"){Sr(y);return}C(I),Jn(y)};h.onNotification("session/update",m=>{if(!b){if(Y!==null){Y.push(m);return}Is(m)}}),h.onNotification("hydra-acp/session/closed",()=>{if(b)return;W>0&&be(-W),typeof te<"u"&&te!==null&&te.setBanner({status:"cold",elapsedMs:void 0})});let Nt=new Map,Pt=200,lt=0,vt=!1,zn=4e3;h.onNotification("hydra-acp/prompt_queue/added",m=>{if(b)return;let y=m??{};if(typeof y.messageId!="string")return;if(typeof y._meta?.["hydra-acp"]?.amending=="string"){let T=y.messageId,R=y.prompt,H=setTimeout(()=>{Nt.delete(T),Re.set(T,Ut(T,R)),te&&X&&pt()},Pt);Nt.set(T,H)}else Re.set(y.messageId,Ut(y.messageId,y.prompt)),te&&X&&pt();if(It!==void 0&&y.originator?.clientId===It){let T=ze.shift();T&&(T.messageId=y.messageId,$t.set(y.messageId,T))}}),h.onNotification("hydra-acp/prompt_queue/updated",m=>{if(b)return;let y=m??{};if(typeof y.messageId!="string"||!Re.has(y.messageId))return;Re.set(y.messageId,Ut(y.messageId,y.prompt));let I=$t.get(y.messageId);if(I){let T=Array.isArray(y.prompt)?y.prompt:[],R="",H=[];for(let z of T){if(!z||typeof z!="object")continue;let D=z;D.type==="text"&&typeof D.text=="string"?R+=D.text:D.type==="image"&&typeof D.data=="string"&&typeof D.mimeType=="string"&&H.push({data:D.data,mimeType:D.mimeType,sizeBytes:Math.floor(D.data.length*3/4)})}I.text=R,I.attachments=H}te&&X&&pt()}),h.onNotification("hydra-acp/prompt_queue/removed",m=>{if(b)return;let y=m??{};if(typeof y.messageId!="string")return;y.reason==="started"&&(N=y.messageId);let I=Nt.get(y.messageId);I!==void 0&&(clearTimeout(I),Nt.delete(y.messageId)),Re.delete(y.messageId)&&te&&X&&pt();let R=$t.get(y.messageId);R&&($t.delete(y.messageId),y.reason==="started"&&(R.flushed=!0,C({kind:"user-text",text:R.displayText,attachments:R.attachments}),ft=R))}),h.onNotification("hydra-acp/cancel_failed",m=>{if(b)return;let y=m??{};if(!(typeof te<"u"&&te!==null))return;lt=Date.now(),vt=!0;let T=typeof y.code=="number"?` (${y.code})`:"",R=typeof y.message=="string"&&y.message.length>0?`: ${y.message}`:"";te.appendLines([{prefix:"\u26A0 ",prefixStyle:"tool-status-fail",body:`cancel rejected by agent${T}${R} \u2014 this agent build may not support cancellation. Cancel again to force-stop (restarts the agent).`,bodyStyle:"tool-status-fail"}])}),h.onNotification("hydra-acp/prompt/amended",m=>{if(b)return;let y=m??{};if(typeof y.cancelledMessageId!="string")return;let I=y.cancelledMessageId;kt.add(I),ft!==null&&ft.messageId!==void 0&&ft.messageId===I&&(C({kind:"turn-complete",stopReason:"cancelled",amended:!0}),ft=null,kt.delete(I))});let Sr=m=>{let y=m??{},I=typeof y.toolCallId=="string"?y.toolCallId:void 0,T;y.outcome&&typeof y.outcome=="object"?T=y.outcome:typeof y.chosenOptionId=="string"&&(T={kind:"selected",optionId:y.chosenOptionId}),kr(I,T?{outcome:T}:void 0)},we=null,kr=(m,y)=>{if(!we||we.toolCallId&&m&&we.toolCallId!==m)return;let I=we.resolve;we=null,S.setPermissionPrompt(null),I(y??{outcome:{outcome:"cancelled"}})},Jn=m=>{if(!we?.toolCallId)return;let y=m??{};y.sessionUpdate!=="tool_call"&&y.sessionUpdate!=="tool_call_update"||y.toolCallId===we.toolCallId&&(!y.status||y.status==="pending"||kr(y.toolCallId,void 0))},Ss=()=>{if(!we){S.setPermissionPrompt(null);return}S.setPermissionPrompt({title:we.title,detail:we.detail,options:we.options.map(m=>({label:m.name})),selectedIndex:we.selectedIndex})},Kn=m=>{if(!we)return;let{options:y,resolve:I}=we;if(we=null,S.setPermissionPrompt(null),m===null){I({outcome:{outcome:"cancelled"}});return}I({outcome:{outcome:"selected",optionId:m}})};h.onRequest("session/request_permission",async m=>{if(b)return{outcome:{outcome:"cancelled"}};if(s.dangerouslySkipPermissions)return gs(m);let y=m??{},T=(Array.isArray(y.options)?y.options:[]).map(se=>({optionId:se.optionId,name:ke(se.name??""),...se.kind!==void 0?{kind:se.kind}:{}})),R=y.toolCall?.title??y.toolCall?.name??"tool",H=ke(R),z=ke(Sm(Im(m))),D=y.toolCall?.toolCallId;return T.length===0?(S.appendLines([{prefix:"\u{1F512} ",body:`Permission requested \xB7 ${H} \xB7 (no options offered, cancelling)`,bodyStyle:"tool-status-fail"}]),{outcome:{outcome:"cancelled"}}):new Promise(se=>{we={title:H,detail:z,options:T,selectedIndex:0,resolve:se,toolCallId:D},Ss()})}),h.setDefaultHandler(async()=>({error:{code:-32601,message:"method not implemented"}}));let Qe,mn,ks=!0,xr=!1;try{let m=await h.request("initialize",{protocolVersion:yt,clientCapabilities:{fs:{readTextFile:!1,writeTextFile:!1},terminal:!1},clientInfo:{name:"hydra-acp-tui",version:me}});mn=m?.agentInfo?.name,m?.agentCapabilities?.promptCapabilities?.image===!1&&(ks=!1),xr=wt(m?._meta??void 0).prompt?.amending===!0}catch{}let Me=a.sessionId,Dt=a.agentId,Oe=a.cwd,hn,It,Vn,Yn,xs,Qn,gn,Gn,yn,fe;if(a.sessionId==="__new__"){let m={};s.agentId&&(m.agentId=s.agentId),s.name&&(m.title=s.name),s.model&&(m.model=s.model);let y=await h.request("session/new",{cwd:a.cwd,...Object.keys(m).length>0?{_meta:{[Ct]:m}}:{}});Me=y.sessionId,r.sessionId=Me,r.readonly=!1;let I=wt(y._meta??void 0);I.clientId&&(It=I.clientId),Qe=I.upstreamSessionId,I.agentId&&(Dt=I.agentId),I.cwd&&(Oe=I.cwd),I.title&&(hn=I.title),Vn=I.currentModel,Yn=I.currentMode,yn=I.currentUsage,fe=I.turnStartedAt,I.availableCommands&&(xs=Ao(I.availableCommands)),I.availableModes&&(Qn=I.availableModes),gn=Ch(y.configOptions),Gn=I.queue}else{let m={};s.readonly===!0&&(m.readonly=!0),e.tui.toolContent==="references"&&(m.toolContent="references"),s.drip===!0&&(m.replayMode="drip",s.dripSpeed!==void 0&&(m.dripSpeed=s.dripSpeed)),a.resumeHint!==void 0&&(m.resume={upstreamSessionId:a.resumeHint.upstreamSessionId,agentId:a.resumeHint.agentId,cwd:a.resumeHint.cwd});let y=await h.request("session/attach",{sessionId:a.sessionId,historyPolicy:"full",clientInfo:{name:"hydra-acp-tui",version:me},...Object.keys(m).length>0?{_meta:{[Ct]:m}}:{}});Me=y.sessionId,y.clientId&&(It=y.clientId),r.sessionId=Me,r.readonly=s.readonly===!0;let I=wt(y._meta??void 0);Qe=I.upstreamSessionId,I.agentId&&(Dt=I.agentId),I.cwd&&(Oe=I.cwd),I.title&&(hn=I.title),Vn=I.currentModel,Yn=I.currentMode,yn=I.currentUsage,fe=I.turnStartedAt,I.availableCommands&&(xs=Ao(I.availableCommands)),I.availableModes&&(Qn=I.availableModes),gn=Ch(y.configOptions),Gn=I.queue}let Zt=P.tuiHistoryFile(Me),vi=P.globalTuiHistoryFile(),Ge=await zr(Zt).catch(()=>[]),St=await zr(vi).catch(()=>[]);St.length>e.tui.promptHistoryMaxEntries&&(St=St.slice(St.length-e.tui.promptHistoryMaxEntries));let Ht=[...Ge],ae=new un({history:io(St,Ht)});X=ae;let We=!1,wn=(m,y)=>{let I=m.replace(/\n+$/,"");if(I.length===0)return;let T=(y??m).replace(/\n+$/,""),R=Jr(Ge,I),H=R!==Ge;Ge=R,Ht=Jr(Ht,T);let z=Jr(St,I,e.tui.promptHistoryMaxEntries),D=z!==St;St=z,ae.setHistory(io(St,Ht)),H&&ls(Zt,Ge).catch(()=>{}),D&&Uu(vi,I).catch(()=>{})};W>0&&ae.setTurnRunning(!0);let Ee=null,As=null;th(e.tui.ambiguousWidth==="wide"),Mp(e.tui.diffContextLines);let Le=!1,S,Ar=()=>{Le&&(Le=!1,S.start())},Ii=()=>{Le||(Le=!0,S.stop(),process.kill(process.pid,"SIGTSTP"))};process.platform!=="win32"&&process.on("SIGCONT",Ar),S=new pa({term:t,dispatcher:ae,repaintThrottleMs:e.tui.repaintThrottleMs,maxScrollbackLines:e.tui.maxScrollbackLines,mouse:i.mouseEnabled,inAppSelection:i.inAppSelectionEnabled,selectionClipboard:e.tui.selectionClipboard,progressIndicator:e.tui.progressIndicator,readonly:s.readonly===!0,onSuspend:process.platform!=="win32"?Ii:void 0,onBlockClick:m=>{Zh(m)},onBlockVisible:m=>{Gh(m)},onMouse:m=>{if(m.kind!=="press"||m.button!=="middle")return;let y={type:"attachment-request",source:"primary"};s.readonly===!0&&Rh(y)||Ae(y)},onKey:m=>{for(let y of m){if(we&&tn(y)||va(y)||M(y)||Cs(y)||Er(y))continue;if(y.type==="attachment-paths"){Mt(y.paths);continue}let I=ae.feed(y);for(let T of I)s.readonly===!0&&Rh(T)||Ae(T)}Tr(),S.setBannerSearchIndicator(ae.state().historySearchQuery),S.setAttachments(ae.state().attachments),S.refreshPrompt()}}),te=S,S.setStickyBottomKey("plan");let bn=[{name:"/help",description:"Show TUI built-in commands"},{name:"/quit",description:"Exit the TUI"},{name:"/clear",description:"Clear scrollback"},{name:"/sessions",description:"List sessions"},{name:"/resume",description:"Switch sessions (open the picker)"},{name:"/rename",description:"Rename this session (alias for /hydra title): /rename [title]"},{name:"/model",description:"Switch model: /model <model-id>"},{name:"/agent",description:"Switch agent via config option: /agent <agent-id>"},{name:"/demo-plan",description:"Inject synthetic plan events (UI test)"},{name:"/demo-tool",description:"Inject a synthetic tool-call sequence (UI test)"}],vn=xs??[],en=Qn??[],In=gn??[],Xn=()=>In.find(m=>m.id==="agent"),Cr=()=>{let m=new Set,y=[];for(let I of[...bn,...vn])m.has(I.name)||(m.add(I.name),y.push(I));return y},Rr=()=>{let m=ae.state().buffer,y=m[0]??"";if(!y.startsWith("/"))return[];if(m.length>1)return[];let I=y.indexOf(" "),T=I===-1?y:y.slice(0,I);if(T.lastIndexOf("/")>0)return[];let R=Cr().filter(H=>H.name.startsWith(T));return R.length===1&&R[0]?.name===T&&I===-1?[]:R},Sn=[],Tr=()=>{let m=Rr();if(m.length>0){Sn=[],S.setCompletions(m);return}S.setCompletions(Sn)},Er=m=>{if(m.type!=="key"||m.name!=="tab")return Sn.length>0&&(Sn=[]),!1;let y=Rr();if(y.length>0){Sn=[];let I=ae.state().buffer[0]??"",T=ch({matches:y.map(R=>R.name),firstLine:I});return T===null||ae.replaceFirstLine(T),!0}return Pr()},Pr=()=>{let m=ae.state(),y=m.buffer[m.row]??"",I=wh(y,m.col);if(I===null)return!1;let T=bh(I.token,Oe);return T===null?!1:(T.replacement!==I.token&&ae.replaceRangeOnCurrentLine(I.start,m.col,T.replacement),Sn=T.candidates.length>1?T.candidates.map(R=>({name:R})):[],!0)},Cs=m=>{if(!S.isScrollbackSearchActive())return m.type==="key"&&m.name==="ctrl-r"&&S.isScrolledBack()?(S.enterScrollbackSearch(),S.updateScrollbackSearchTerm(""),!0):!1;if(m.type==="char"){let y=S.scrollbackSearchTerm()+m.ch;return S.updateScrollbackSearchTerm(y),!0}if(m.type==="paste"){let y=S.scrollbackSearchTerm()+m.text.replace(/\n/g," ");return S.updateScrollbackSearchTerm(y),!0}if(m.type==="key")switch(m.name){case"ctrl-r":return S.advanceScrollbackSearch(),!0;case"ctrl-s":return S.retreatScrollbackSearch(),!0;case"backspace":{let y=S.scrollbackSearchTerm();return y.length===0?S.cancelScrollbackSearch():S.updateScrollbackSearchTerm(y.slice(0,-1)),!0}case"enter":return S.acceptScrollbackSearch(),!0;case"escape":case"ctrl-c":return S.cancelScrollbackSearch(),!0;default:return!0}return!0},tn=m=>{if(!we)return!1;let y=we.options;if(m.type==="key")switch(m.name){case"up":return we.selectedIndex=Math.max(0,we.selectedIndex-1),Ss(),!0;case"down":return we.selectedIndex=Math.min(y.length-1,we.selectedIndex+1),Ss(),!0;case"enter":{let I=y[we.selectedIndex];return I&&Kn(I.optionId),!0}case"escape":case"ctrl-c":return Kn(null),!0;default:return!0}if(m.type==="char"&&/^[1-9]$/.test(m.ch)){let I=parseInt(m.ch,10)-1,T=y[I];return T&&Kn(T.optionId),!0}return!0},kn=Dt||mn||"?",nt={...yn??{}};c.finalize(),S.start({skipFullscreen:!0}),S.setHideThoughts(!i.showThoughts),S.setSessionbar({agent:kn,cwd:Oe,sessionId:Me,title:hn,model:Vn,usage:{...nt}}),Yn&&S.setBanner({currentMode:Yn}),li().then(m=>{m&&S.notify(`\u2728 ${ui(m)}`,3e4)});let ut=null,Si=new Promise(m=>{ut=m}),ki=()=>{h.notify("session/cancel",{sessionId:Me}).catch(()=>{})},Mr=()=>{te!==null&&W===1&&(Q=!0,te.setBanner({status:"cancelling",elapsedMs:void 0,stalled:!1}))},xn=()=>{if(Ee){Ee.cancel(),Mr();return}if(W>0){ki(),Mr();return}$r()},$r=()=>{K(0)},xi=()=>{let m="enqueue prompt (sends now, or queues during a turn)",y="amend the in-flight turn (cancel + replace)";return[...i.defaultEnterAction==="amend"?[["Enter",y],["Ctrl+Enter / Shift+Enter / ^S",m]]:[["Enter",m],["Ctrl+Enter / Shift+Enter / ^S",y]],...Xk]},Lc=()=>{if(S.isHelpPromptActive()){S.setHelpPrompt(null);return}S.setHelpPrompt({title:"Hotkeys",entries:xi(),hint:"any key dismisses \xB7 /help lists commands"})},va=m=>S.isHelpPromptActive()?(m.type==="key"&&m.name==="ctrl-g",S.setHelpPrompt(null),!0):!1,Zn=["tools","plan","thoughts","diffs","mouse","enter"],Xe=0,nn=m=>{switch(m){case"tools":return i.toolsExpanded?"expanded":"collapsed";case"plan":return i.planExpanded?"expanded":"collapsed";case"thoughts":return i.showThoughts?"shown":"hidden";case"diffs":return i.showFileUpdates;case"mouse":return i.mouseEnabled?"on":"off";case"enter":return i.defaultEnterAction}},st=m=>{switch(m){case"tools":return"Tools";case"plan":return"Plan";case"thoughts":return"Thoughts";case"diffs":return"File updates";case"mouse":return"Mouse capture";case"enter":return"Enter key"}},Rs=()=>({title:"Session options",options:Zn.map(m=>({label:st(m),value:nn(m)})),selectedIndex:Xe}),Ts=()=>{S.isOptionsPromptActive()&&S.setOptionsPrompt(Rs())},Ai=()=>{if(S.isOptionsPromptActive()){S.setOptionsPrompt(null);return}Xe=0,S.setOptionsPrompt(Rs())},es=m=>{switch(m){case"tools":i.toolsExpanded=!i.toolsExpanded,E.clear(),Yh();break;case"plan":i.planExpanded=!i.planExpanded,Ze=null,Rn();break;case"thoughts":i.showThoughts=!i.showThoughts,S.setHideThoughts(!i.showThoughts);break;case"diffs":i.showFileUpdates=i.showFileUpdates==="diff"?"edit":"diff",sn.clear(),Xh();break;case"mouse":{let y=!S.isMouseEnabled();S.setMouseEnabled(y),i.mouseEnabled=y;break}case"enter":i.defaultEnterAction=i.defaultEnterAction==="amend"?"enqueue":"amend";break}Ts()},k=m=>{(async()=>{try{switch(m){case"tools":case"plan":S.notify(`${st(m)} is session-only \u2014 not saved`);return;case"thoughts":await Lr("showThoughts",i.showThoughts);break;case"diffs":await Lr("showFileUpdates",i.showFileUpdates);break;case"mouse":await Lr("mouse",i.mouseEnabled);break;case"enter":await Lr("defaultEnterAction",i.defaultEnterAction);break}S.notify(`saved default: ${st(m)} ${nn(m)}`)}catch(y){S.notify(`save failed: ${y instanceof Error?y.message:String(y)}`)}})()},M=m=>{if(!S.isOptionsPromptActive())return!1;if(m.type==="key")switch(m.name){case"up":return Xe=Math.max(0,Xe-1),Ts(),!0;case"down":return Xe=Math.min(Zn.length-1,Xe+1),Ts(),!0;case"enter":{let y=Zn[Xe];return y&&es(y),!0}case"ctrl-o":case"escape":case"ctrl-c":return S.setOptionsPrompt(null),!0;case"ctrl-d":return S.setOptionsPrompt(null),!1;default:return!0}if(m.type==="char"){if(/^[1-9]$/.test(m.ch)){let y=parseInt(m.ch,10)-1,I=Zn[y];return I&&(Xe=y,es(I)),!0}if(m.ch==="s"||m.ch==="S"){let y=Zn[Xe];return y&&k(y),!0}}return!0},_=()=>{b=!0,process.off("SIGINT",xn),process.platform!=="win32"&&process.off("SIGCONT",Ar),U!==null&&(clearInterval(U),U=null),S.clearWindowTitle(),S.stop({keepFullscreen:!0}),ls(Zt,Ge).catch(()=>{}),g.close().catch(()=>{})},K=(m=0)=>{_(),ut&&(ut(null),ut=null),m!==0&&process.exit(m)},ce=async()=>{if(!ut)return;let m=ae.state().buffer.join(`
|
|
213
|
+
`);m.replace(/\s+$/,"").length>0&&wn(m),S.pauseRepaint(),S.stop({keepFullscreen:!0}),ls(Zt,Ge).catch(()=>{});let y=null,I=null;for(;y===null;){let z=await cn(n,{includeNonInteractive:!0}),D=await Pc(t,{cwd:Oe,sessions:z,config:e,target:n,currentSessionId:Me,prefs:o});if(D.kind==="abort"){S.start({skipFullscreen:!0}),S.resumeRepaint();return}if(D.kind==="exit"){K(0);return}if(D.kind==="new"){y={choice:D,sessions:z};break}if(D.kind==="fork"){let Ke=await $h(t,n,D,z);if(Ke.kind==="cancel"){S.start({skipFullscreen:!0}),S.resumeRepaint();return}if(Ke.kind==="back")continue;y={choice:{kind:"attach",sessionId:Ke.ctx.sessionId,...Ke.ctx.agentId?{agentId:Ke.ctx.agentId}:{}},sessions:z},I={readonly:!1,cwd:Ke.ctx.cwd},Ke.ctx.resumeHint!==void 0&&(I.resumeHint=Ke.ctx.resumeHint);break}let se=z.find(Ke=>Ke.sessionId===D.sessionId);if(!(se!==void 0&&!!se.importedFromMachine&&!se.upstreamSessionId&&D.readonly!==!0)){if(n.isLocal&&se&&!se.importedFromMachine&&D.readonly!==!0&&!(await pi(se.cwd)).ok){let at=await bi(t,se,{defaultCwd:Ft(e.defaultCwd),title:"Working directory missing \u2014 choose cwd",intro:"This session's working directory no longer exists. Pick a new one:"});if(at.kind==="cancel"){S.start({skipFullscreen:!0}),S.resumeRepaint();return}if(at.kind==="back")continue;y={choice:D,sessions:z},I={readonly:!1,cwd:at.path,resumeHint:{agentId:D.agentId??se.agentId??"",cwd:at.path,upstreamSessionId:""}};break}y={choice:D,sessions:z};break}let Se={...s,readonly:!1},De=await Mh(t,se,D,Se);if(De.kind==="cancel"){S.start({skipFullscreen:!0}),S.resumeRepaint();return}De.kind!=="back"&&(y={choice:D,sessions:z},I={readonly:Se.readonly===!0,cwd:De.ctx.cwd},De.ctx.resumeHint!==void 0&&(I.resumeHint=De.ctx.resumeHint))}let{choice:T}=y,R=ut;if(ut=null,process.off("SIGINT",xn),g.close().catch(()=>{}),T.kind==="new"){let{sessionId:z,...D}=s,se={...D,cwd:Oe,forceNew:!0,readonly:!1};T.prompt!==void 0&&(se.initialPrompt=T.prompt),R(se);return}if(T.kind!=="attach")return;let H={...s,sessionId:T.sessionId,cwd:I?.cwd??Oe,readonly:I?.readonly??T.readonly===!0};T.agentId!==void 0&&(H.agentId=T.agentId),I?.resumeHint!==void 0?H.resumeHint=I.resumeHint:delete H.resumeHint,R(H)},ve=async()=>{if(!ut)return;let y=(await cn(n)).filter(z=>z.status==="live");if(y.length<=1)return;let I=y.findIndex(z=>z.sessionId===Me),T=y[(I+1)%y.length],R=ut;ut=null,process.off("SIGINT",xn),g.close().catch(()=>{});let H={...s,sessionId:T.sessionId,cwd:Oe,readonly:!1};T.agentId!==void 0&&(H.agentId=T.agentId),R(H)},Ae=m=>{switch(m.type){case"send":i.defaultEnterAction==="amend"?Ci(m.text,m.attachments,m.displayText):_r(m.text,m.attachments,m.displayText);return;case"amend":i.defaultEnterAction==="amend"?_r(m.text,m.attachments,m.displayText):Ci(m.text,m.attachments,m.displayText);return;case"queue-edit":{let y=Es(m.index);if(!y)return;let I=[];m.text.length>0&&I.push({type:"text",text:m.text});for(let T of m.attachments)I.push({type:"image",data:T.data,mimeType:T.mimeType});h.request("hydra-acp/prompt/update",{sessionId:Me,messageId:y,prompt:I}).then(T=>{let R=T;!R.updated&&R.reason!=="ok"&&S.notify(`queue edit skipped (${R.reason})`)}).catch(T=>{S.notify(`queue edit failed: ${T.message}`)});return}case"queue-remove":{let y=Es(m.index);if(!y)return;h.request("hydra-acp/prompt/cancel",{sessionId:Me,messageId:y}).then(I=>{let T=I;!T.cancelled&&T.reason!=="ok"&&S.notify(`queue cancel skipped (${T.reason})`)}).catch(I=>{S.notify(`queue cancel failed: ${I.message}`)});return}case"cancel":{if(m.prefill&&Ee){let y=Re.size===0,I=ae.state().buffer.every(T=>T==="");y&&I&&(As={text:Ee.text,attachments:Ee.attachments})}Ee?Ee.cancel():W>0&&ki(),Mr();return}case"exit":$r();return;case"plan-toggle":Ia(m.on);return;case"redraw-banner":S.setBanner({});return;case"redraw":S.fullRedraw();return;case"scroll-to-top":S.scrollToTop();return;case"scroll-to-bottom":S.scrollToBottom();return;case"switch-session":ce();return;case"next-live-session":ve();return;case"toggle-options":Ai();return;case"toggle-thoughts":i.showThoughts=!i.showThoughts,S.setHideThoughts(!i.showThoughts),S.notify(i.showThoughts?"thoughts shown":"thoughts hidden");return;case"toggle-mouse":{let y=!S.isMouseEnabled();S.setMouseEnabled(y),i.mouseEnabled=y,S.notify(y?"mouse capture on \u2014 wheel scrolls; shift+drag to select text":"mouse capture off \u2014 click-drag selects text; PgUp/PgDn scrolls");return}case"show-help":Lc();return;case"escalate-search":S.enterScrollbackSearch(),S.updateScrollbackSearchTerm(m.query);return;case"attachment-request":ts(m.source);return}},Mt=async m=>{if(!ks){S.notify("agent does not accept image attachments");return}let y=0;for(let I of m){if(I.startsWith("data:")){let R=ac(I);if(!R){S.notify("unsupported data: URI");continue}if(R.sizeBytes>Xt){S.notify(`image too large (${Et(R.sizeBytes)}, max ${Et(Xt)})`);continue}ae.addAttachment({mimeType:R.mimeType,data:R.data,name:"pasted image",sizeBytes:R.sizeBytes}),y++;continue}let T=mi(I);if(!T){S.notify(`unsupported image type: ${$c.basename(I)}`);continue}try{let R=await Qk.readFile(I);if(R.length>Xt){S.notify(`image too large (${Et(R.length)}, max ${Et(Xt)})`);continue}ae.addAttachment({mimeType:T,data:R.toString("base64"),name:$c.basename(I),sizeBytes:R.length}),y++}catch(R){S.notify(`cannot read ${$c.basename(I)}: ${R.message}`)}}y>0&&(S.setAttachments(ae.state().attachments),S.refreshPrompt())},ts=async(m="clipboard")=>{let y=m==="primary"?await qm():await jm();if(!y.ok){S.notify(y.reason);return}if(y.kind==="image"){if(!ks){S.notify("agent does not accept image attachments");return}ae.addAttachment(y.attachment),S.setAttachments(ae.state().attachments),S.refreshPrompt();return}let I=ae.feed({type:"paste",text:y.text});for(let T of I)Ae(T);S.refreshPrompt()},ns=m=>m.attachmentCount>0?`${m.text} \xB7 \u{1F4CE}\xD7${m.attachmentCount}`:m.text,Ut=(m,y)=>{let I=Array.isArray(y)?y:[],T="",R=0;for(let H of I){if(!H||typeof H!="object")continue;let z=H;z.type==="text"&&typeof z.text=="string"?T+=z.text:z.type==="image"&&(R+=1)}return{messageId:m,text:ke(T),attachmentCount:R}},Re=new Map,ze=[],$t=new Map,kt=new Set,ft=null,pt=()=>{let m=[...Re.values()],y=m.map(ns);S.setQueuedPrompts(y),S.setBanner({queued:m.length}),ae.setQueue(m.map(I=>I.text))},Es=m=>[...Re.values()][m]?.messageId;if(Gn&&Gn.length>0){for(let m of Gn){if(m.position===0){N=m.messageId;continue}Re.set(m.messageId,Ut(m.messageId,m.prompt))}Re.size>0&&pt()}let _r=(m,y,I)=>{S.scrollToBottom(),!Ri(m)&&(wn(m,I),Fr(m,y,I))},Ci=(m,y,I)=>{if(S.scrollToBottom(),Ri(m))return;if(wn(m,I),!xr||N===void 0){Fr(m,y,I);return}let T=N,R=[];m.length>0&&R.push({type:"text",text:m});for(let D of y)R.push({type:"image",data:D.data,mimeType:D.mimeType});let H={text:m,displayText:I??m,attachments:y,flushed:!1};ze.push(H);let z=()=>{let D=ze.indexOf(H);D>=0&&ze.splice(D,1),H.messageId!==void 0&&$t.delete(H.messageId)};h.request("hydra-acp/prompt/amend",{sessionId:Me,targetMessageId:T,prompt:R}).then(D=>{let se=D;if(se.amended&&se.reason==="ok"){be(1);return}if(z(),se.reason==="target_completed"){S.notify("previous response finished \u2014 press Enter to send as a new turn"),ae.setBuffer(m,y),S.refreshPrompt();return}if(se.reason==="target_cancelled"){S.notify("amend skipped \u2014 previous turn was cancelled"),ae.setBuffer(m,y),S.refreshPrompt();return}if(se.reason==="target_not_found"){S.notify("amend skipped \u2014 no matching prompt"),ae.setBuffer(m,y),S.refreshPrompt();return}}).catch(D=>{z(),S.notify(`amend failed: ${D.message}`),ae.setBuffer(m,y),S.refreshPrompt()})},Ia=async m=>{if(en.length===0){S.notify("no modes advertised by agent");return}let y=S.currentModeId(),I=en.findIndex(H=>H.id===y),T=I===-1?0:(I+1)%en.length,R=en[T]?.id;if(R){S.setBanner({currentMode:R});try{await h.request("session/set_mode",{sessionId:Me,modeId:R})}catch(H){S.notify(`set_mode failed: ${H.message}`)}}},Ri=m=>{let y=m.replace(/\s+$/,"");if(!y.startsWith("/")||y.includes(`
|
|
214
|
+
`))return!1;let I=y.indexOf(" ");switch(I===-1?y:y.slice(0,I)){case"/quit":case"/exit":return $r(),!0;case"/clear":return Te.clear(),Cn.clear(),rn.length=0,$=null,ee=null,G=null,An.clear(),sn.clear(),rs.clear(),E.clear(),j.clear(),oe.clear(),S.clearScrollback(),!0;case"/demo-plan":{S.clearKey("plan");let R=["Step 1","Step 2","Step 3","Step 4","Step 5"],H=[["pending","pending","pending","pending","pending"],["in_progress","pending","pending","pending","pending"],["completed","in_progress","pending","pending","pending"],["completed","completed","in_progress","pending","pending"],["completed","completed","completed","in_progress","pending"],["completed","completed","completed","completed","in_progress"],["completed","completed","completed","completed","completed"]],z=0,D=()=>{let se=H[z];se&&(C({kind:"plan",entries:R.map((Ce,Se)=>({content:Ce,status:se[Se]??"pending"}))}),z+=1,setTimeout(D,600))};return D(),!0}case"/demo-tool":{let R=`demo-${Date.now()}`;return C({kind:"tool-call",toolCallId:R,title:"Terminal",status:"pending"}),setTimeout(()=>{C({kind:"tool-call-update",toolCallId:R,title:"echo hello world",status:"in_progress"})},500),setTimeout(()=>{C({kind:"tool-call-update",toolCallId:R,status:"completed"})},1500),!0}case"/help":{let R=[{prefix:" ",body:"Built-in commands:",bodyStyle:"system"}];for(let H of bn)R.push({prefix:" ",body:` ${H.name.padEnd(12)} ${H.description??""}`,bodyStyle:"info"});if(vn.length>0){R.push({prefix:" ",body:"Agent commands:",bodyStyle:"system"});for(let H of vn)R.push({prefix:" ",body:` ${H.name.padEnd(12)} ${H.description??""}`,bodyStyle:"info"})}return S.appendLines(R),!0}case"/agent":{let R=I===-1?"":y.slice(I+1).trim(),H=Xn();if(!H)return S.appendLines([{prefix:" ",body:"no agent config option advertised for this session",bodyStyle:"info"}]),!0;if(!R){let z=[{prefix:" ",body:"Available agents:",bodyStyle:"system"}];for(let D of H.options){let se=D.value===H.currentValue?"* ":" ";z.push({prefix:" ",body:`${se}${D.value.padEnd(16)} ${D.name}`,bodyStyle:"info"})}return S.appendLines(z),!0}return H.options.some(z=>z.value===R)?R===H.currentValue?(S.notify(`already on agent ${R}`),!0):(S.notify(`switching to ${R}\u2026`),h.request("session/set_config_option",{sessionId:Me,configId:"agent",value:R}).catch(z=>{S.notify(`set_config_option failed: ${z.message}`)}),!0):(S.notify(`unknown agent: ${R}`),!0)}case"/sessions":return S.appendLines([{prefix:" ",body:"Run `hydra-acp sessions` (or `hydra sessions`) for the full list.",bodyStyle:"info"}]),!0;case"/resume":return ce(),!0;case"/rename":{let R=I===-1?"":y.slice(I+1).trim(),H=R.length>0?`/hydra title ${R}`:"/hydra title";return wn(y,y),Fr(H,[],y),!0}default:return!1}},Fr=async(m,y,I)=>{let T=[];m.length>0&&T.push({type:"text",text:m});for(let Se of y)T.push({type:"image",data:Se.data,mimeType:Se.mimeType});be(1);let R={text:m,displayText:I??m,attachments:y,flushed:!1};ze.push(R),vt=!1;let H=!1,z=null,D=Se=>{typeof te<"u"&&te!==null&&te.appendLines([{prefix:"\u26A0 ",prefixStyle:"tool-status-fail",body:Se,bodyStyle:"tool-status-fail"}])},se=!1;Ee={text:m,attachments:y,cancel:()=>{if(vt){vt=!1,se=!0,D("force-stopping agent \u2014 turn aborted; resumes on your next message\u2026"),h.request("hydra-acp/session/force_cancel",{sessionId:Me}).catch(De=>{D(`force-stop failed: ${De.message}`)});return}if(H)return;H=!0,h.notify("session/cancel",{sessionId:Me}).catch(()=>{});let Se=Date.now();z=setTimeout(()=>{Ee!==null&&(lt>=Se||(vt=!0,D("cancel not acknowledged by agent \u2014 the turn is still running. Cancel again to force-stop (restarts the agent).")))},zn)}};let Ce;try{let Se=await h.request("session/prompt",{sessionId:Me,prompt:T});Se&&typeof Se.stopReason=="string"&&(Ce=Se.stopReason)}catch(Se){let De=ze.indexOf(R);De>=0&&ze.splice(De,1),R.messageId!==void 0&&$t.delete(R.messageId),se?S.appendLines([{prefix:"\u26A0 ",prefixStyle:"tool-status-fail",body:"turn force-stopped",bodyStyle:"tool-status-fail"}]):S.appendLines([{prefix:"\u2717 ",prefixStyle:"tool-status-fail",body:Se.message,bodyStyle:"tool-status-fail"}])}finally{if(Ee=null,z!==null&&(clearTimeout(z),z=null),be(-1),R.flushed&&ft===R){let Se=R.messageId!==void 0&&kt.has(R.messageId);Se&&R.messageId!==void 0&&kt.delete(R.messageId);let De={kind:"turn-complete"};Ce!==void 0&&(De.stopReason=Ce),Se&&(De.amended=!0),C(De),ft=null}if(As!==null){let{text:Se,attachments:De}=As;As=null,ae.state().buffer.every(at=>at==="")&&(ae.setBuffer(Se,De),S.refreshPrompt())}}},Te=new Map,An=new Map,sn=new Map,Cn=new Map,rn=[],ss=0,jt=`tools:${ss}`,rs=new Map,E=new Map,j=new Map,oe=new Map,$=null,ee=null,G=null,le=null,Ze=null,Je=e.tui.maxToolItems,_t=e.tui.maxPlanItems,$e=()=>({maxPlanItems:Ze??i.planExpanded?1/0:_t}),Rn=()=>{if(le===null)return;let m=pr(le,$e());m.length>0&&S.upsertLines("plan",[{body:""},...m])},Ps="",Ms=null,Bc=0,qh=()=>{if(Ms===null)return;let m=S.width(),y=mr(Ps,m>0?{maxWidth:m}:void 0);y.length!==0&&S.upsertLines(Ms,y)},Wh=m=>{m.length!==0&&(Ms===null&&(S.ensureSeparator(),Ms=`agent:${Bc}`,Bc+=1,Ps=""),Ps+=m,qh())},Tn=()=>{Ms=null,Ps=""},$s="",is=null,Nc=0,zh=()=>({prefix:" ",body:"\u25B8 Thoughts",bodyStyle:"thought"}),Jh=()=>{if(is===null||$s.length===0)return;let m=Nd($s);m.length!==0&&S.upsertLines(is,m)},Kh=m=>{let y=j.get(m);if(y===void 0)return[];let I=Nd(y.text);return y.workerTaskId&&I.unshift({prefix:" ",body:`[T${y.workerTaskId}] `,bodyStyle:"dim"}),I},Vh=(m,y)=>{m.length!==0&&(is===null&&(S.ensureSeparator("thought"),is=`thought:${Nc}`,Nc+=1,$s=""),$s+=m,j.set(is,{text:$s,workerTaskId:y}),Jh())},En=()=>{is=null,$s=""},Dc=m=>{let{order:y,states:I,startedAt:T,endedAt:R,stopReason:H}=m,z=y.length,D=Je>0,se=!D||m.expanded?y:y.slice(Math.max(0,z-Je)),Ce=z-se.length,Se=R===null,De=R??Date.now(),Ke=De-T,at=!Se&&H!==null&&H!=="end_turn"?H:null,Vc=at==="amended",Yc=Vc?`amended \xB7 ${Gt(Ke)}`:`stopped (${at}) \xB7 ${Gt(Ke)}`,Mi;if(z===0)at!==null?Mi=Yc:Mi=Se?`thinking \xB7 ${Gt(Ke)}`:`thought \xB7 ${Gt(Ke)}`;else{let ka=z===1?"tool":"tools",$i=at!==null?Yc:Se?Gt(Ke):`took ${Gt(Ke)}`,Zc=[`${z} ${ka}`,$i];Se&&D&&Ce>0&&Zc.push(`${Ce} hidden`),Mi=Zc.join(" \xB7 ")}let Qc=z===0&&Se,Gc=Vc?"tool-status-cancelled":"tool-status-fail",Xc=[{prefix:"\u2699 ",prefixStyle:Qc?"tool-status-running":at!==null?Gc:"tool",body:Mi,bodyStyle:Qc?"tool-status-running":at!==null?Gc:"dim"}];for(let ka of se){let $i=I.get(ka);$i&&Xc.push(...Ep($i,De))}return Xc},Hc=m=>E.get(m)??i.toolsExpanded,xt=()=>{if($===null)return;let m=Dc({order:rn,states:Te,startedAt:$,endedAt:ee,stopReason:G,expanded:Hc(jt)});S.upsertLines(jt,m)},Uc=m=>{let y=rs.get(m);if(!y)return;let I=Dc({order:y.order,states:y.states,startedAt:y.startedAt,endedAt:y.endedAt,stopReason:y.stopReason,expanded:Hc(m)});S.upsertLines(m,I)},Yh=()=>{$!==null&&!rs.has(jt)&&xt();for(let m of rs.keys())Uc(m)},Sa=()=>{$!==null&&rs.set(jt,{order:[...rn],states:new Map(Te),startedAt:$,endedAt:ee??Date.now(),stopReason:G})},jc=()=>{ss+=1,jt=`tools:${ss}`,$=Date.now(),ee=null,G=null,xt()},qc=(m,y,I,T,R,H,z)=>{let D=!Te.has(m),se=Te.get(m),Ce=se??{initialTitle:y??"tool",latestTitle:y??"tool",status:I??"pending",startedAt:Date.now()};!se&&z!==void 0&&(Ce.workerTaskId=z),se&&y!==void 0&&(Ce.latestTitle=y),H!==void 0&&Ce.detail===void 0&&(Ce.detail=H),se&&I!==void 0&&(Ce.status=I),se||(Ce.status=I??"pending"),Ce.endedAt===void 0&&Fp(Ce.status)&&(Ce.endedAt=Date.now()),T!==void 0&&(Ce.errorText=T),R!==void 0&&(Ce.editDiff=R),Te.set(m,Ce),D&&($===null&&(ss+=1,jt=`tools:${ss}`,$=Date.now(),ee=null,G=null),rn.push(m))},Wc=async m=>{try{let y=await h.request("hydra-acp/session/tool_content",{sessionId:Me,hash:m});return typeof y?.content=="string"?y.content:null}catch{return null}},Ti=new Set,Qh=(m,y)=>{Ti.has(m)||y.oldRef===void 0&&y.newRef===void 0||(Ti.add(m),(async()=>{let[I,T]=await Promise.all([y.oldRef?Wc(y.oldRef.hash):Promise.resolve(y.oldText),y.newRef?Wc(y.newRef.hash):Promise.resolve(y.newText)]);if(y.oldRef!==void 0&&I===null||y.newRef!==void 0&&T===null){Ti.delete(m);let Ce=Dd(y,"diff",{deferredStatus:"error"});Ce.length>0&&(S.upsertLines(`editdiff:${m}`,Ce),S.repaintNow());return}let H={...y.path!==void 0?{path:y.path}:{},oldText:I??"",newText:T??""};An.set(m,H);let z=Te.get(m);z?.editDiff&&(z.editDiff=H),Ti.delete(m);let D=sn.get(m),se=D===void 0?i.showFileUpdates:D?"diff":"edit";se!=="none"&&(Ei(m,H,se==="diff"?"diff":"edit"),S.repaintNow())})())},Ei=(m,y,I)=>{let T=`editdiff:${m}`,R=Dd(y,I);if(R.length===0){S.removeKey(T);return}S.upsertLines(T,R),I==="diff"&&(y.oldRef!==void 0||y.newRef!==void 0)&&S.notifyWhenVisible(T)},Gh=m=>{if(!m.startsWith("editdiff:"))return;let y=m.slice(9),I=An.get(y);I&&(I.oldRef!==void 0||I.newRef!==void 0)&&Qh(y,I)},zc=m=>{let y=`editdiff:${m}`,I=i.showFileUpdates,T=Te.get(m),R;if(I==="none"||!T?.editDiff||T.status!=="completed")R=null;else{let z=sn.get(m);R=z!==void 0?z?"diff":"edit":I==="diff"?"diff":"edit"}if(R===null){S.removeKey(y);return}let H=T.editDiff;An.set(m,H),Ei(m,H,R)},Xh=()=>{let m=i.showFileUpdates;for(let[y,I]of An){let T=`editdiff:${y}`,R=sn.get(y),H=R===void 0?m:R?"diff":"edit";if(H==="none"){S.removeKey(T);continue}Ei(y,I,H==="diff"?"diff":"edit")}},Zh=m=>{if(m.startsWith("editdiff:")){let y=m.slice(9),I=An.get(y);if(!I)return;let T=sn.get(y)??i.showFileUpdates==="diff";sn.set(y,!T),Ei(y,I,T?"edit":"diff"),S.repaintNow();return}if(m==="plan"){if(le===null)return;Ze=!(Ze??i.planExpanded),Rn(),S.repaintNow();return}if(m.startsWith("tools:")){let y=E.get(m)??i.toolsExpanded;E.set(m,!y),m===jt&&$!==null?xt():Uc(m),S.repaintNow();return}if(m.startsWith("thought:")){if(!j.has(m))return;let y=oe.get(m);if(y!==void 0){oe.delete(m),S.setRunCollapsed(y,!1,Kh(m)),S.repaintNow();return}let I=S.contiguousRun(m,new Set(j.keys()));if(I.length===0)return;let T=I[0];oe.set(T,I),S.setRunCollapsed(I,!0,[zh()]),S.repaintNow();return}};v=m=>{if(m.kind==="available-commands"){vn=m.commands,Tr();return}if(m.kind==="available-modes"){en=m.modes;return}if(m.kind==="config-options"){In=m.options;let I=m.options.find(R=>R.id==="agent");I&&I.currentValue&&I.currentValue!==Dt&&(Dt=I.currentValue,S.setSessionbar({agent:I.currentValue}));let T=m.options.find(R=>R.id==="mode");T&&(en=T.options.map(R=>({id:R.value,name:R.name??R.value,...R.description!==void 0?{description:R.description}:{}})));return}if(m.kind==="mode-changed"){S.setBanner({currentMode:m.mode||void 0});return}if(m.kind==="session-info"){m.title!==void 0&&S.setSessionbar({title:m.title}),m.agentId!==void 0&&m.agentId!==Dt&&(Dt=m.agentId,S.setSessionbar({agent:m.agentId}));return}if(m.kind==="usage-update"){let I=!1;m.used!==void 0&&nt.used!==m.used&&(nt.used=m.used,I=!0),m.size!==void 0&&nt.size!==m.size&&(nt.size=m.size,I=!0),m.costAmount!==void 0&&nt.costAmount!==m.costAmount&&(nt.costAmount=m.costAmount,I=!0),m.costCurrency!==void 0&&nt.costCurrency!==m.costCurrency&&(nt.costCurrency=m.costCurrency,I=!0),I&&S.setSessionbar({usage:{...nt}});return}if(m.kind==="user-text"){We&&wn(m.text),Tn(),En(),$!==null&&(ee=Date.now(),xt()),ft=null,S.ensureSeparator();let I=pr(m);I.length>0&&S.appendLines(I),Sa(),S.clearKey("plan"),le=null,Ze=null,Te.clear(),Cn.clear(),rn.length=0,ee=null,jc(),S.redraw();return}if(m.kind==="agent-text"){En(),Ms===null&&q(m.workerTaskId),Wh(m.text);return}if(m.kind==="agent-thought"){Tn(),is===null&&q(m.workerTaskId),Vh(m.text,m.workerTaskId);return}if(m.kind==="exit-plan-mode"){Tn(),En();let I=Cn.get(m.toolCallId),T={plan:m.plan??I?.plan??"",status:m.status??I?.status};if(Cn.set(m.toolCallId,T),T.plan.length===0)return;let R=Op(T);R.length>0&&S.upsertLines(m.toolCallId,R);return}if(m.kind==="tool-call"){Tn(),En(),Te.has(m.toolCallId)||q(m.workerTaskId),qc(m.toolCallId,m.title,m.status,void 0,m.editDiff,m.detail,m.workerTaskId),xt(),zc(m.toolCallId);return}if(m.kind==="plan"){Tn(),En(),le=m;let I=pr(m,$e());I.length>0&&S.upsertLines("plan",[{body:""},...I]);let T=m.entries.length>0&&m.entries.every(R=>(R.status??"pending")==="completed");S.setStickyBottomKey(T?null:"plan");return}if(m.kind==="tool-call-update"){Tn(),En(),qc(m.toolCallId,m.title,m.status,m.errorText,m.editDiff,m.detail,m.workerTaskId),m.upstreamInterrupted&&(ie=!0),xt(),zc(m.toolCallId);return}m.kind==="model-changed"&&S.setSessionbar({model:m.model});let y=pr(m);if(y.length>0&&S.appendLines(y),m.kind==="turn-complete"){N=void 0,Tn(),En();let I=m.amended?"amended":m.stopReason;if(!m.amended&&ie&&(I===void 0||I==="end_turn")&&(I="error"),le!==null&&I!==void 0&&I!=="end_turn"){let T=pr({...le,stopped:!0,amended:m.amended===!0},$e());T.length>0&&S.upsertLines("plan",[{body:""},...T])}le=null,Ze=null,S.clearKey("plan"),S.setStickyBottomKey("plan"),$!==null?(ee=Date.now(),G=I??null,xt(),Sa()):I!==void 0&&I!=="end_turn"&&I!=="amended"&&S.appendLines([{prefix:"\u26A0 ",prefixStyle:"tool-status-fail",body:`turn ended: ${I}`,bodyStyle:"tool-status-fail"}]),Te.clear(),Cn.clear(),rn.length=0,$=null,ee=null,G=null,ie=!1,S.ensureSeparator(),Sh({pendingTurns:W,queueSize:Re.size,ownTurnInFlight:Ee!==null,hasInFlightHead:N!==void 0,replayDraining:x,amended:m.amended===!0})&&be(-W)}};let Jc=w;w=[];let Pi=[];for(let m of Jc)m.kind==="user-text"&&typeof m.text=="string"&&Pi.push(m.text);S.pauseRepaint(),x=!0;try{for(let m of Jc)v(m)}finally{x=!1,S.resumeRepaint()}if(Pi.length>0){let m=gd(Ge,Pi);m!==Ge&&(Ge=m,Ht=gd(Ht,Pi),ae.setHistory(io(St,Ht)),ls(Zt,Ge).catch(()=>{}))}We=!0,fe!==void 0&&W>0?(F=fe,S.setBanner({status:"busy",elapsedMs:Date.now()-fe}),U===null&&(U=setInterval(()=>{F===null||te===null||(te.setBanner({elapsedMs:Date.now()-F}),xt())},1e3)),$===null&&jc(),$=fe,xt()):fe===void 0&&W>0&&be(-W);let eg=()=>{if(we){let m=we.resolve;we=null,S.setPermissionPrompt(null),m({outcome:{outcome:"cancelled"}})}Tn(),En()},Kc=()=>{$!==null&&(ee=Date.now(),G="reconnect-recovery-failed",xt(),Sa(),Te.clear(),Cn.clear(),rn.length=0,$=null,ee=null,G=null)};return p=()=>{S.setBanner({status:"disconnected",elapsedMs:void 0})},u=async()=>{eg();let m={jsonrpc:"2.0",id:`tui-reinit-${Ah()}`,method:"initialize",params:{protocolVersion:yt,clientCapabilities:{fs:{readTextFile:!1,writeTextFile:!1},terminal:!1},clientInfo:{name:"hydra-acp-tui",version:me}}};try{await g.request(m)}catch{}let y=Ie!==void 0,I={jsonrpc:"2.0",id:`tui-reattach-${Ah()}`,method:"session/attach",params:{sessionId:Me,historyPolicy:y?"after_message":"none",...y?{afterMessageId:Ie}:{},clientInfo:{name:"hydra-acp-tui",version:me},...(()=>{let D={};return Qe!==void 0&&(D.resume={upstreamSessionId:Qe,agentId:Dt,cwd:Oe}),e.tui.toolContent==="references"&&(D.toolContent="references"),Object.keys(D).length>0?{_meta:{[Ct]:D}}:{}})()}};Y=[];let T,R,H;try{let D=await g.request(I);if(D.error)throw new Error(D.error.message);H=Ih(D.result),T=H.appliedPolicy,H.clientId!==void 0&&(It=H.clientId)}catch(D){R=D}let z=Y??[];if(Y=null,R)Kc(),S.appendLines([{prefix:" ",body:`reattach failed: ${R.message}`,bodyStyle:"tool-status-fail"}]);else if(y&&T!=="after_message")Kc(),S.appendLines([{prefix:"\u26A0 ",prefixStyle:"tool-status-fail",body:"reconnect couldn't replay events since last seen \u2014 scrollback may be incomplete",bodyStyle:"tool-status-fail"}]);else{x=!0;try{for(let D of z)Is(D)}finally{x=!1}}if(H){let D=kh({daemonTurnStartedAt:H.turnStartedAt,pendingTurns:W});D.pendingTurnsDelta!==0&&be(D.pendingTurnsDelta),D.banner==="busy"&&D.busySince!==void 0?(F=D.busySince,S.setBanner({status:"busy",elapsedMs:Date.now()-D.busySince}),U===null&&(U=setInterval(()=>{F===null||te===null||(te.setBanner({elapsedMs:Date.now()-F}),xt())},1e3))):S.setBanner({status:"ready",elapsedMs:void 0})}else S.setBanner({status:W>0?"busy":"ready",elapsedMs:W>0?0:void 0})},h.onClose(m=>{m&&t.red(`
|
|
195
215
|
connection lost: ${m.message}
|
|
196
|
-
`),K(m?1:0)}),process.on("SIGINT",xn),s.initialPrompt&&a.sessionId==="__new__"&&_r(s.initialPrompt,[]),await Si}async function
|
|
197
|
-
`),null)}for(;;){let o=await cn(n,{includeNonInteractive:!0}),a=await Pc(t,{cwd:i,sessions:o,config:e,target:n,prefs:r,...s.initialPrompt!==void 0?{initialPrompt:s.initialPrompt}:{}});if(a.kind==="abort"||a.kind==="exit")return null;if(a.kind==="new"){a.prompt!==void 0&&(s.initialPrompt=a.prompt);let l=await
|
|
216
|
+
`),K(m?1:0)}),process.on("SIGINT",xn),s.initialPrompt&&a.sessionId==="__new__"&&_r(s.initialPrompt,[]),await Si}async function ex(t,e,n,s,r){let i=s.cwd??process.cwd();if(s.sessionId){let o={sessionId:s.sessionId,agentId:s.agentId??"",cwd:i};return s.resumeHint!==void 0&&(o.resumeHint=s.resumeHint),o}if(s.forceNew)return await Eh(t,n,s)!=="ok"?null:Th(s,i,e);if(s.resume){let o=await cn(n,{cwd:i,all:!0}),a=jo(o,i);return a?{sessionId:a.sessionId,agentId:a.agentId??"",cwd:i}:(t.yellow(`No sessions found for ${i}.
|
|
217
|
+
`),null)}for(;;){let o=await cn(n,{includeNonInteractive:!0}),a=await Pc(t,{cwd:i,sessions:o,config:e,target:n,prefs:r,...s.initialPrompt!==void 0?{initialPrompt:s.initialPrompt}:{}});if(a.kind==="abort"||a.kind==="exit")return null;if(a.kind==="new"){a.prompt!==void 0&&(s.initialPrompt=a.prompt);let l=await Eh(t,n,s);if(l==="cancel")return null;if(l==="back")continue;return Th(s,i,e)}if(a.kind==="fork"){let l=await $h(t,n,a,o);if(l.kind==="cancel")return null;if(l.kind==="back")continue;return l.ctx}s.readonly=a.readonly===!0;let d=o.find(l=>l.sessionId===a.sessionId);if(d!==void 0&&!!d.importedFromMachine&&!d.upstreamSessionId&&!s.readonly){let l=await Mh(t,d,a,s);if(l.kind==="cancel")return null;if(l.kind==="back")continue;return l.ctx}if(n.isLocal&&d&&!d.importedFromMachine&&!s.readonly&&!(await pi(d.cwd)).ok){let f=await bi(t,d,{defaultCwd:Ft(e.defaultCwd),title:"Working directory missing \u2014 choose cwd",intro:"This session's working directory no longer exists. Pick a new one:"});if(f.kind==="cancel")return null;if(f.kind==="back")continue;let u=a.agentId??d.agentId??"";return{sessionId:a.sessionId,agentId:u,cwd:f.path,resumeHint:{agentId:u,cwd:f.path,upstreamSessionId:""}}}return{sessionId:a.sessionId,agentId:a.agentId??"",cwd:i}}}async function Mh(t,e,n,s){for(;;){let r=await rh(t,e);if(r==="cancel")return{kind:"cancel"};if(r==="back")return{kind:"back"};if(r==="view"){s.readonly=!0;let a=n.agentId??e.agentId??"";return{kind:"ctx",ctx:{sessionId:n.sessionId,agentId:a,cwd:e.cwd}}}let i=await bi(t,e);if(i.kind==="cancel")return{kind:"cancel"};if(i.kind==="back")continue;let o=n.agentId??e.agentId??"";return{kind:"ctx",ctx:{sessionId:n.sessionId,agentId:o,cwd:i.path,resumeHint:{agentId:o,cwd:i.path,upstreamSessionId:""}}}}}async function $h(t,e,n,s){let r=s.find(d=>d.sessionId===n.sourceSessionId),i=!!n.sourceImportedFromMachine&&!n.sourceUpstreamSessionId,o=n.sourceCwd;if(i){if(!r)return{kind:"back"};let d=await bi(t,r);if(d.kind==="cancel")return{kind:"cancel"};if(d.kind==="back")return{kind:"back"};o=d.path}let a;try{a=await ip(e,n.sourceSessionId,i?{cwd:o}:{})}catch(d){return t.red(`
|
|
198
218
|
fork failed: ${d.message}
|
|
199
|
-
`),{kind:"cancel"}}return{kind:"ctx",ctx:{sessionId:a.sessionId,agentId:n.sourceAgentId??"",cwd:o,...i?{resumeHint:{agentId:n.sourceAgentId??"",cwd:o,upstreamSessionId:""}}:{}}}}function
|
|
200
|
-
`)}catch{}}function
|
|
201
|
-
`))}}}function
|
|
219
|
+
`),{kind:"cancel"}}return{kind:"ctx",ctx:{sessionId:a.sessionId,agentId:n.sourceAgentId??"",cwd:o,...i?{resumeHint:{agentId:n.sourceAgentId??"",cwd:o,upstreamSessionId:""}}:{}}}}function Th(t,e,n){return{sessionId:"__new__",agentId:t.agentId??n.defaultAgent??"",cwd:e}}async function Eh(t,e,n){if(n.agentId||await pl())return"ok";let s;try{s=await rp(e)}catch{return"ok"}if(s.length===0)return"ok";let r=await ph(t,s);if(r.kind==="cancel")return"cancel";if(r.kind==="back")return"back";if(n.agentId=r.agentId,r.persist)try{await Oi(r.agentId)}catch{}return"ok"}function tx(t,e){nx({src:"session/update",update:t,event:e===null?null:{kind:e.kind}})}function nx(t){let e=process.env.HYDRA_TUI_DEBUG_LOG,n=e===void 0?P.tuiLogFile():e;if(n.length!==0)try{rx(n);let s=JSON.stringify({t:new Date().toISOString(),...t});Jk(n,`${s}
|
|
220
|
+
`)}catch{}}function sx(t,e){let n=!1,s="",r=!1,i=d=>{n||d===3&&r||d===0&&!r||(r=d===3,process.stdout.write(`\x1B]9;4;${d}\x1B\\`))},o=d=>{n||(process.stdout.write("\r"),t.eraseLineAfter(),t.brightYellow(d),s=d)},a=d=>{let c=`${d.agentId}@${d.version}`;if(d.source==="npm")return d.phase==="install_start"||d.phase==="download_start"?`${e} installing ${c} via npm\u2026`:d.phase==="installed"?`${e} ${c} installed`:`${e} installing ${c} via npm\u2026`;if(d.phase==="download_start"||d.phase==="download_progress"){let l=d.receivedBytes??0,f=d.totalBytes??0,u=(l/1e6).toFixed(1);if(f>0){let p=(f/1e6).toFixed(1),g=Math.min(100,Math.floor(l/f*100));return`${e} downloading ${c} ${u}/${p} MB (${g}%)`}return`${e} downloading ${c} ${u} MB`}return d.phase==="download_done"?`${e} downloaded ${c}, verifying\u2026`:d.phase==="extract"?`${e} extracting ${c}\u2026`:d.phase==="installed"?`${e} ${c} installed`:s||e};return{write(d){n||(t.brightYellow(d),s=d)},applyProgress(d){if(n)return;d.phase==="download_start"||d.phase==="download_progress"||d.phase==="install_start"||d.phase==="extract"||d.phase==="download_done"?i(3):d.phase==="installed"&&i(0),o(a(d))},finalize(){n||(n=!0,i(0),process.stdout.write(`
|
|
221
|
+
`))}}}function rx(t){try{if(Kk(t).size<_h)return;Vk(t,`${t}.0`)}catch{}}var Gk,Xk,_h,Fh=V(()=>{"use strict";Nr();dt();Zd();Ne();rc();Us();ri();wo();Ni();Yt();ue();Lt();na();nc();oo();qo();dh();uh();Ac();mh();Ic();oc();aa();uc();wa();vh();xh();ms();di();Gk=12e4;Xk=[["Alt+Enter","newline in prompt"],["Shift+Tab","cycle agent modes (plan / accept-edits / etc.)"],["Tab","indent \xB7 slash-command / file-path completion"],null,["\u2191 / \u2193","prompt history \xB7 queue navigation"],["\u2190/\u2192 Home/End","cursor movement"],["Alt+B / Alt+F","word back / forward"],["^A / ^E","line start / end"],["^W / ^U / ^K","kill word / line / to end"],["^Y","yank last kill"],null,["^P","switch session (picker)"],["Alt+N / Alt+Tab","next live session"],["^T","show / hide thoughts"],["^V","paste image from clipboard"],["^O","session options (tools \xB7 plan \xB7 thoughts \xB7 diffs \xB7 mouse \xB7 enter)"],null,["^R","history reverse search (^S walks forward once engaged)"],["PgUp / PgDn","scroll scrollback"],["Mouse wheel","scroll scrollback (when mouse capture is on)"],["Middle-click","paste PRIMARY selection (terminal-style)"],["^X","toggle mouse capture (wheel scroll vs. text selection)"],null,["^C","cancel turn (twice to exit)"],["Esc","cancel turn and prefill draft"],["^D","exit (or delete-forward in prompt)"],["^L","force full redraw"],["^G","toggle this help"]];_h=5*1024*1024});var Oh={};ng(Oh,{runTui:()=>Ph});var Lh=V(()=>{"use strict";Fh()});import{readFileSync as ix}from"fs";import{fileURLToPath as ox}from"url";import{dirname as ax,resolve as dx}from"path";var el=new Set(["all","dangerously-skip-permissions","detach","diff","disabled","drip","fold","follow","force","foreground","help","include-cat","info","json","new","no-color","no-pager","raw","reattach","readonly","replace","rotate-token","verbose","version"]),sg=new Set(["agent","args","columns","command","cwd","drip-speed","env","host","model","name","out","prompt","session","stream-bytes","stream-threshold","tail"]);function tl(t){for(let e of Object.keys(t))if(!el.has(e)&&!sg.has(e))return e}function xa(t){let e=[],n={},s=0;for(;s<t.length;){let r=t[s];if(r===void 0)break;if(r.startsWith("--")){let i=r.indexOf("=");if(i!==-1){let d=r.slice(2,i);n[d]=r.slice(i+1),s+=1;continue}let o=r.slice(2);if(el.has(o)){n[o]=!0,s+=1;continue}let a=t[s+1];if(a!==void 0&&!a.startsWith("--")){n[o]=a,s+=2;continue}n[o]=!0,s+=1;continue}e.push(r),s+=1}return{positional:e,flags:n}}function rg(t,e){let n=t[e];if(typeof n=="string")return n}function _s(t,e){return t[e]===!0||t[e]==="true"}var ig="HYDRA_ACP_";function og(t){return ig+t.toUpperCase().replace(/-/g,"_")}function Ve(t,e){let n=rg(t,e);return n!==void 0?n:process.env[og(e)]}Ne();Us();async function Sl(t,e){let n=typeof t=="string"&&t.trim().length>0?t.trim():void 0;if(n===void 0)return;if(n.startsWith("hydra://")){let i=Ea(n);return{target:await vl(i,{allowPrompt:e.allowPrompt}),sessionId:i.sessionId,fromUrl:!0}}let s=await Z();return{target:await Wt(s),sessionId:n,fromUrl:!1}}function Oa(t){let e=t.session;if(typeof e=="string"&&e.length>0)return e;let n=process.env.HYDRA_ACP_SESSION;if(typeof n=="string"&&n.length>0)return n}ue();Ne();mt();import*as kl from"fs/promises";async function xl(t){if(await kl.mkdir(P.home(),{recursive:!0}),await Fi(),!await Ls()){let n=Os();await Bs(n),process.stdout.write(`Initialized ${P.authToken()}
|
|
202
222
|
Service token: ${n}
|
|
203
|
-
`);return}if(
|
|
223
|
+
`);return}if(_s(t,"rotate-token")){let n=Os();await Bs(n),process.stdout.write(`Rotated token in ${P.authToken()}
|
|
204
224
|
New token: ${n}
|
|
205
225
|
`);return}process.stdout.write(`Service token already exists at ${P.authToken()}.
|
|
206
226
|
`),process.stdout.write(`Pass --rotate-token to generate a new service token.
|
|
207
|
-
`)}ue();Ne();mt();import*as
|
|
208
|
-
`)};function Ua(t){
|
|
209
|
-
`))}async function Bl(t){if(!t.target.archive)throw new Error(`Agent ${t.agentId} has no archive URL for ${zt()??"this platform"}`);if(!t.target.cmd)throw new Error(`Agent ${t.agentId} has no cmd in its binary target`);let e=zt();if(!e)throw new Error(`Agent ${t.agentId}: cannot determine platform key for ${process.platform}/${process.arch}`);let n=P.agentInstallDir(t.agentId,e,t.version),s=Mn.resolve(n,t.target.cmd);if(await Da(s))return s;if(await
|
|
227
|
+
`)}ue();Ne();mt();import*as Gf from"fs/promises";import{setTimeout as wv}from"timers/promises";import Qf from"chalk";import*as Kf from"fs";import*as Bn from"fs/promises";import cv from"fastify";import lv from"@fastify/websocket";var Al="acp.v1";function Cl(t,e){return t.has(Al)?Al:!1}Ne();import Jf from"pino";import uv from"pino-roll";ue();import*as et from"fs/promises";import{createHash as Ag}from"crypto";import{gzip as Cg,gunzip as Rg}from"zlib";import{promisify as Rl}from"util";var Tl=Rl(Cg),Tg=Rl(Rg),El=/^[A-Za-z0-9_-]+$/,Eg=/^[a-f0-9]{64}$/,La=!0;function Pl(t){La=t}function Di(t,e){return El.test(t)?e===void 0||Eg.test(e):!1}function Hi(t,e){return`${P.toolBlobFile(t,e)}.gz`}async function Ba(t,e){if(!Di(t))return null;let n=Ag("sha256").update(e,"utf8").digest("hex"),s=Hi(t,n),r=P.toolBlobFile(t,n);for(let a of[s,r])try{return await et.access(a),n}catch{}await et.mkdir(P.toolsDir(t),{recursive:!0});let i=La?s:r,o=La?await Tl(Buffer.from(e,"utf8")):Buffer.from(e,"utf8");return await et.writeFile(i,o,{mode:384,flag:"wx"}).catch(async a=>{if(a.code!=="EEXIST")throw a}),n}async function Ui(t,e){if(!Di(t,e))return null;try{let n=await et.readFile(Hi(t,e));return(await Tg(n)).toString("utf8")}catch{}try{return await et.readFile(P.toolBlobFile(t,e),"utf8")}catch{return null}}async function Ml(t,e){if(!Di(t,e))return null;try{return await et.readFile(Hi(t,e))}catch{}try{let n=await et.readFile(P.toolBlobFile(t,e));return await Tl(n)}catch{return null}}async function $l(t,e,n){if(!Di(t,e))return;let s=Hi(t,e);try{await et.access(s);return}catch{}await et.mkdir(P.toolsDir(t),{recursive:!0}),await et.writeFile(s,n,{mode:384,flag:"wx"}).catch(r=>{if(r.code!=="EEXIST")throw r})}async function _l(t){El.test(t)&&await et.rm(P.toolsDir(t),{recursive:!0,force:!0}).catch(()=>{})}ue();os();import*as Wl from"fs/promises";import*as qi from"path";import{z as re}from"zod";ue();import*as Ol from"fs";import*as rt from"fs/promises";import*as Mn from"path";import{spawn as Ll}from"child_process";import{Readable as Pg}from"stream";function zt(){let t=process.platform==="darwin"?"darwin":process.platform==="linux"?"linux":process.platform==="win32"?"windows":void 0,e=process.arch==="arm64"?"aarch64":process.arch==="x64"?"x86_64":void 0;if(!(!t||!e))return`${t}-${e}`}function Ha(t,e=zt()){if(e)return t[e]}var js=t=>{process.stderr.write(t+`
|
|
228
|
+
`)};function Ua(t){js=t??(e=>process.stderr.write(e+`
|
|
229
|
+
`))}async function Bl(t){if(!t.target.archive)throw new Error(`Agent ${t.agentId} has no archive URL for ${zt()??"this platform"}`);if(!t.target.cmd)throw new Error(`Agent ${t.agentId} has no cmd in its binary target`);let e=zt();if(!e)throw new Error(`Agent ${t.agentId}: cannot determine platform key for ${process.platform}/${process.arch}`);let n=P.agentInstallDir(t.agentId,e,t.version),s=Mn.resolve(n,t.target.cmd);if(await Da(s))return s;if(await Mg({agentId:t.agentId,version:t.version,archiveUrl:t.target.archive,installDir:n,onProgress:t.onProgress}),!await Da(s))throw new Error(`Agent ${t.agentId}: extracted archive did not contain ${t.target.cmd} (looked in ${n})`);return process.platform!=="win32"&&await rt.chmod(s,493).catch(()=>{}),s}async function Mg(t){await rt.mkdir(Mn.dirname(t.installDir),{recursive:!0});let e=await rt.mkdtemp(`${t.installDir}.partial-`);try{js(`hydra-acp: downloading ${t.agentId} from ${t.archiveUrl}`);let n=await $g({url:t.archiveUrl,dir:e,agentId:t.agentId,version:t.version,onProgress:t.onProgress});js(`hydra-acp: extracting ${t.agentId}`),qs(t.onProgress,{phase:"extract",agentId:t.agentId,version:t.version}),await Fg(n,e),await rt.unlink(n).catch(()=>{});try{await rt.rename(e,t.installDir)}catch(s){let r=s;if((r.code==="EEXIST"||r.code==="ENOTEMPTY")&&await Da(t.installDir)){await rt.rm(e,{recursive:!0,force:!0}).catch(()=>{}),qs(t.onProgress,{phase:"installed",agentId:t.agentId,version:t.version});return}throw s}js(`hydra-acp: installed ${t.agentId} to ${t.installDir}`),qs(t.onProgress,{phase:"installed",agentId:t.agentId,version:t.version})}catch(n){throw await rt.rm(e,{recursive:!0,force:!0}).catch(()=>{}),n}}function qs(t,e){if(t)try{t(e)}catch{}}async function $g(t){let e=_g(t.url),n=Mn.join(t.dir,e),s=await fetch(t.url,{redirect:"follow"});if(!s.ok||!s.body)throw new Error(`Failed to download ${t.url}: HTTP ${s.status} ${s.statusText}`);let r=Number(s.headers.get("content-length")??"0"),i=Ol.createWriteStream(n),o=Pg.fromWeb(s.body);qs(t.onProgress,{phase:"download_start",agentId:t.agentId,version:t.version,totalBytes:r});let a=0,d=Date.now(),c=0,l=2e3,f=150;return o.on("data",u=>{a+=u.length;let p=Date.now();p-c>=f&&(c=p,qs(t.onProgress,{phase:"download_progress",agentId:t.agentId,version:t.version,receivedBytes:a,totalBytes:r})),p-d>=l&&(d=p,js(Fl(t.agentId,a,r)))}),await new Promise((u,p)=>{o.on("error",p),i.on("error",p),i.on("finish",()=>u()),o.pipe(i)}),js(Fl(t.agentId,a,r,!0)),qs(t.onProgress,{phase:"download_done",agentId:t.agentId,version:t.version,receivedBytes:a,totalBytes:r}),n}function Fl(t,e,n,s=!1){let r=(e/1e6).toFixed(1);if(n>0){let o=(n/1e6).toFixed(1),a=Math.min(100,Math.floor(e/n*100));return`hydra-acp: ${s?"downloaded":"downloading"} ${t} ${r}/${o} MB (${a}%)`}return`hydra-acp: ${s?"downloaded":"downloading"} ${t} ${r} MB`}function _g(t){let e=new URL(t);return Mn.posix.basename(e.pathname)||"archive"}async function Fg(t,e){let n=t.toLowerCase();if(n.endsWith(".tar.gz")||n.endsWith(".tgz")||n.endsWith(".tar")){await Na("tar",["-xf",t,"-C",e]);return}if(n.endsWith(".zip")){if(await Og("unzip")){await Na("unzip",["-q",t,"-d",e]);return}await Na("tar",["-xf",t,"-C",e]);return}throw new Error(`Unsupported archive format: ${t}`)}function Na(t,e){return new Promise((n,s)=>{let r=Ll(t,e,{stdio:["ignore","ignore","inherit"]});r.on("error",s),r.on("exit",(i,o)=>{if(i===0){n();return}s(new Error(`${t} ${e.join(" ")} exited with ${i!==null?`code ${i}`:`signal ${o}`}`))})})}async function Og(t){return new Promise(e=>{let n=process.platform==="win32"?"where":"which",s=Ll(n,[t],{stdio:"ignore"});s.on("error",()=>e(!1)),s.on("exit",r=>e(r===0))})}async function Da(t){try{return await rt.access(t),!0}catch{return!1}}ue();import*as gt from"fs/promises";import*as Jt from"path";import{spawn as Lg}from"child_process";var qa=t=>{process.stderr.write(t+`
|
|
210
230
|
`)};function Wa(t){qa=t??(e=>process.stderr.write(e+`
|
|
211
|
-
`))}async function Dl(t){let e=zt();if(!e)throw new Error(`Agent ${t.agentId}: cannot determine platform key for ${process.platform}/${process.arch}`);let n=P.agentNpmInstallDir(t.agentId,e,t.version),s=
|
|
212
|
-
stderr: ${l}`:`npm install ${t.packageSpec} failed (${c})`))})})}catch(n){if(n.code==="ETXTBSY"&&e<
|
|
231
|
+
`))}async function Dl(t){let e=zt();if(!e)throw new Error(`Agent ${t.agentId}: cannot determine platform key for ${process.platform}/${process.arch}`);let n=P.agentNpmInstallDir(t.agentId,e,t.version),s=Ug(t.packageSpec),r=jg(s),i={installDir:n,packageName:s,hint:t.bin,basename:r},o=Jt.join(n,"node_modules",".bin",t.bin);if(await as(o))return o;if(await as(n)){let f=await Nl(i);if(f)return f.binPath}await Bg({agentId:t.agentId,version:t.version,packageSpec:t.packageSpec,installDir:n,registry:t.registry,onProgress:t.onProgress});let a=await Nl(i);if(a)return a.binPath;let d=await Ul(n,s),c=typeof d=="object"&&d!==null?Object.keys(d):typeof d=="string"?[r]:[],l=c.length>0?` (package declares bins: ${c.join(", ")})`:"";throw new Error(`Agent ${t.agentId}: npm install of ${t.packageSpec} did not produce bin ${t.bin} (looked in ${n}/node_modules/.bin/)${l}`)}async function Bg(t){await gt.mkdir(Jt.dirname(t.installDir),{recursive:!0});let e=await gt.mkdtemp(`${t.installDir}.partial-`);try{qa(`hydra-acp: installing ${t.packageSpec} for ${t.agentId} into ${e}`),ja(t.onProgress,{phase:"install_start",agentId:t.agentId,version:t.version,packageSpec:t.packageSpec}),await Hg({packageSpec:t.packageSpec,cwd:e,registry:t.registry});try{await gt.rename(e,t.installDir)}catch(n){let s=n;if((s.code==="EEXIST"||s.code==="ENOTEMPTY")&&await as(t.installDir)){await gt.rm(e,{recursive:!0,force:!0}).catch(()=>{}),ja(t.onProgress,{phase:"installed",agentId:t.agentId,version:t.version});return}throw n}qa(`hydra-acp: installed ${t.agentId} to ${t.installDir}`),ja(t.onProgress,{phase:"installed",agentId:t.agentId,version:t.version})}catch(n){throw await gt.rm(e,{recursive:!0,force:!0}).catch(()=>{}),n}}function ja(t,e){if(t)try{t(e)}catch{}}var Ng=5,Dg=25;function Hg(t){return Hl(t,0)}async function Hl(t,e){try{await new Promise((n,s)=>{let r=t.registry?["--registry",t.registry]:[],i;try{i=Lg("npm",["install","--no-audit","--no-fund","--silent",...r,t.packageSpec],{cwd:t.cwd,stdio:["ignore","pipe","pipe"]})}catch(a){s(a);return}let o="";i.stdout?.on("data",a=>{}),i.stderr?.setEncoding("utf8"),i.stderr?.on("data",a=>{o=(o+a).slice(-4096)}),i.on("error",a=>{if(a.code==="ENOENT"){s(new Error("npm not found on PATH (install Node.js / npm, or use a binary-distributed agent)"));return}s(a)}),i.on("exit",(a,d)=>{if(a===0){n();return}let c=a!==null?`exit code ${a}`:`signal ${d??"unknown"}`,l=o.trim();s(new Error(l?`npm install ${t.packageSpec} failed (${c})
|
|
232
|
+
stderr: ${l}`:`npm install ${t.packageSpec} failed (${c})`))})})}catch(n){if(n.code==="ETXTBSY"&&e<Ng)return await new Promise(r=>setTimeout(r,Dg*(e+1))),Hl(t,e+1);throw n}}function Ug(t){if(t.startsWith("@")){let n=t.indexOf("/");if(n===-1)return t;let r=t.slice(n+1).indexOf("@");return r===-1?t:t.slice(0,n+1+r)}let e=t.indexOf("@");return e<=0?t:t.slice(0,e)}function jg(t){let e=t.lastIndexOf("/");return e===-1?t:t.slice(e+1)}async function Ul(t,e){let n=Jt.join(t,"node_modules",e,"package.json");try{let s=await gt.readFile(n,"utf8"),r=JSON.parse(s);return typeof r.bin=="string"||typeof r.bin=="object"&&r.bin!==null&&!Array.isArray(r.bin)?r.bin:void 0}catch{return}}async function Nl(t){let e=Jt.join(t.installDir,"node_modules",".bin"),n=Jt.join(e,t.hint);if(await as(n))return{binName:t.hint,binPath:n};let s=await Ul(t.installDir,t.packageName);if(typeof s=="object"&&s!==null){let r=Object.keys(s);if(r.length===1){let i=r[0],o=Jt.join(e,i);if(await as(o))return{binName:i,binPath:o}}else if(r.length>1){for(let i of[t.hint,t.basename])if(r.includes(i)){let o=Jt.join(e,i);if(await as(o))return{binName:i,binPath:o}}}}if(t.basename!==t.hint){let r=Jt.join(e,t.basename);if(await as(r))return{binName:t.basename,binPath:r}}}async function as(t){try{return await gt.access(t),!0}catch{return!1}}var qg=re.object({package:re.string(),bin:re.string().optional(),args:re.array(re.string()).optional(),env:re.record(re.string()).optional()}),Ws=re.object({archive:re.string().url().optional(),cmd:re.string().optional(),args:re.array(re.string()).optional(),env:re.record(re.string()).optional()}),Wg=re.object({"darwin-aarch64":Ws.optional(),"darwin-x86_64":Ws.optional(),"linux-aarch64":Ws.optional(),"linux-x86_64":Ws.optional(),"windows-x86_64":Ws.optional(),"windows-aarch64":Ws.optional()}),zg=re.object({package:re.string(),args:re.array(re.string()).optional(),env:re.record(re.string()).optional()}),Jg=re.object({command:re.string(),args:re.array(re.string()).optional(),env:re.record(re.string()).optional()}),Kg=re.object({npx:qg.optional(),binary:Wg.optional(),uvx:zg.optional(),exec:Jg.optional()}),Vg=re.object({id:re.string(),name:re.string(),version:re.string().optional(),description:re.string().optional(),authors:re.array(re.string()).optional(),license:re.string().optional(),icon:re.string().optional(),repository:re.string().optional(),website:re.string().optional(),distribution:Kg}),jl=re.object({version:re.string(),agents:re.array(Vg),extensions:re.array(re.unknown()).optional()}),ji=class{constructor(e,n={}){this.config=e;this.options=n}config;options;cache;async load(){if(this.cache&&(this.isPinned()||this.isFresh(this.cache.fetchedAt)))return this.cache.data;let e=await this.readDiskCache();if(e&&(this.isPinned()||this.isFresh(e.fetchedAt)))return this.cache=e,e.data;try{let n=await this.fetchFromNetwork();return this.cache=n,await this.writeDiskCache(n),n.data}catch(n){if(e)return this.cache=e,e.data;throw n}}async refresh(){let e=await this.fetchFromNetwork();return this.cache=e,await this.writeDiskCache(e),e.data}lastFetchedAt(){return this.cache?.fetchedAt}async getAgent(e){let n=this.localAgents().find(o=>o.id===e);if(n)return n;let s=await this.load(),r=s.agents.find(o=>o.id===e);if(r)return this.applyOverride(r);let i=s.agents.find(o=>za(o)===e);return i?this.applyOverride(i):void 0}localAgents(){return Object.entries(this.config.agents??{}).map(([e,n])=>({id:e,name:n.name??e,description:n.description,version:"local",distribution:{exec:{command:n.command??e,args:n.args,env:n.env}}}))}applyOverride(e){let n=this.config.agentOverrides?.[e.id];return!n?.packageSpec||!e.distribution.npx?e:{...e,version:Yg(n.packageSpec),distribution:{...e.distribution,npx:{...e.distribution.npx,package:n.packageSpec}}}}isPinned(){return this.config.registry?.pinned===!0}isFresh(e){let n=Date.now()-e,s=this.config.registry.ttlHours*60*60*1e3;return n<s}async fetchFromNetwork(){let e=await fetch(this.config.registry.url);if(!e.ok)throw new Error(`Registry fetch failed: HTTP ${e.status}`);let n=await e.json(),s=jl.parse(n),r={fetchedAt:Date.now(),raw:n,data:s},i=this.options.onFetched;return i&&Promise.resolve().then(()=>i(s)).catch(()=>{}),r}async readDiskCache(){let e=await At(P.registryCache());if(!(!e||typeof e.fetchedAt!="number"||e.data===void 0))try{let n=jl.parse(e.data);return{fetchedAt:e.fetchedAt,raw:e.data,data:n}}catch{return}}async writeDiskCache(e){await ht(P.registryCache(),{fetchedAt:e.fetchedAt,data:e.raw})}};function Yg(t){let e=t.lastIndexOf("@"),s=(e>0?t.slice(e+1):"").replace(/[^a-zA-Z0-9._-]/g,"_");return s.length>0?`pin-${s}`:"pinned"}function za(t){let e=t.distribution.npx?.package;if(!e)return;let n=e.lastIndexOf("/"),s=n===-1?e:e.slice(n+1),r=s.lastIndexOf("@");return r<=0?s:s.slice(0,r)}async function zs(t){let e=typeof t.localAgents=="function"?t.localAgents():[],n;try{n=await t.load()}catch(o){if(e.length===0)throw o;n={version:"local-only",agents:[]}}let s=new Set(e.map(o=>o.id)),r=[...e,...n.agents.filter(o=>!s.has(o.id))],i=await Promise.all(r.map(async o=>({id:o.id,name:o.name,version:o.version,description:o.description,distributions:Object.keys(o.distribution),installed:await Ja(o),source:s.has(o.id)?"local":"registry"})));return{version:n.version,fetchedAt:t.lastFetchedAt(),agents:i}}async function Ja(t){let e=zt();if(!e)return"no";let n=t.version??"current";if(t.distribution.exec)return"yes";if(t.distribution.binary){let s=Ha(t.distribution.binary,e);if(s?.cmd){let r=qi.resolve(P.agentInstallDir(t.id,e,n),s.cmd);if(await ql(r))return"yes"}}if(t.distribution.npx){let s=t.distribution.npx,r=s.bin??za(t)??s.package,i=P.agentNpmInstallDir(t.id,e,n),o=qi.join(i,"node_modules",".bin",r);if(await ql(o))return"yes"}return!t.distribution.npx&&!t.distribution.binary&&t.distribution.uvx?"lazy":"no"}async function ql(t){try{return await Wl.access(t),!0}catch{return!1}}async function $n(t,e=[],n={}){let s=t.version??"current";if(t.distribution.npx){let r=t.distribution.npx,i=e.length>0?e:r.args??[];if(process.env.HYDRA_ACP_SKIP_NPM_PREFETCH)return{command:"npx",args:["-y",r.package,...i],env:r.env??{},version:s};let o=r.bin??za(t)??r.package,a=n.onInstallProgress;return{command:await Dl({agentId:t.id,version:s,packageSpec:r.package,bin:o,registry:n.npmRegistry,onProgress:a?c=>a({source:"npm",...c}):void 0}),args:i,env:r.env??{},version:s}}if(t.distribution.binary){let r=Ha(t.distribution.binary);if(!r)throw new Error(`Agent ${t.id} has no binary distribution for ${zt()??"this platform"}.`);let i=n.onInstallProgress,o=await Bl({agentId:t.id,version:s,target:r,onProgress:i?d=>i({source:"binary",...d}):void 0}),a=e.length>0?e:r.args??[];return{command:o,args:a,env:r.env??{},version:s}}if(t.distribution.uvx){let r=t.distribution.uvx,i=e.length>0?e:r.args??[];return{command:"uvx",args:[r.package,...i],env:r.env??{},version:s}}if(t.distribution.exec){let r=t.distribution.exec,i=e.length>0?e:r.args??[];return{command:r.command,args:i,env:r.env??{},version:s}}throw new Error(`Agent ${t.id} has no usable distribution method.`)}import{spawn as ey}from"child_process";import*as Yi from"fs";import*as ru from"path";dt();function Vi(t,e){let n="",s=[],r=[],i=!1,o=a=>{if(!i){i=!0;for(let d of r)d(a)}};return t.setEncoding("utf8"),t.on("data",a=>{n+=a;let d=n.indexOf(`
|
|
213
233
|
`);for(;d!==-1;){let c=n.slice(0,d).trim();if(n=n.slice(d+1),c.length>0)try{let l=JSON.parse(c);for(let f of s)f(l)}catch(l){for(let f of s)f({jsonrpc:"2.0",id:0,error:{code:B.ParseError,message:`Failed to parse ndjson line: ${l.message}`}})}d=n.indexOf(`
|
|
214
234
|
`)}}),t.on("end",()=>o()),t.on("error",a=>o(a)),e.on("error",a=>o(a)),{async send(a){if(i)throw new Error("stream is closed");let d=JSON.stringify(a)+`
|
|
215
|
-
`;await new Promise((c,l)=>{e.write(d,f=>{if(f){l(f);return}c()})})},onMessage(a){s.push(a)},onClose(a){r.push(a)},async close(){e.end(),o()}}}Nr();ue();var
|
|
235
|
+
`;await new Promise((c,l)=>{e.write(d,f=>{if(f){l(f);return}c()})})},onMessage(a){s.push(a)},onClose(a){r.push(a)},async close(){e.end(),o()}}}Nr();ue();var ty=4096,_n=class t{agentId;version;cwd;connection;child;exited=!1;killed=!1;stderrTail="";stderrTailBytes;killEscalationMs;logger;fileLog;exitHandlers=[];constructor(e,n){if(this.agentId=e.agentId,this.version=e.plan.version,this.cwd=e.cwd,this.child=n,this.stderrTailBytes=e.stderrTailBytes??ty,this.killEscalationMs=e.killEscalationMs??ny,this.logger=e.logger,this.fileLog=sy(e.agentId),this.writeLog(`--- spawn pid=${n.pid} version=${e.plan.version} cwd=${e.cwd} cmd=${e.plan.command} args=${JSON.stringify(e.plan.args)} time=${new Date().toISOString()} ---
|
|
216
236
|
`),!n.stdout||!n.stdin)throw new Error("agent subprocess missing stdio");let s=Vi(n.stdout,n.stdin);this.connection=new Kt(s),n.stderr?.setEncoding("utf8"),n.stderr?.on("data",r=>{if(this.stderrTail=(this.stderrTail+r).slice(-this.stderrTailBytes),this.writeLog(r),this.logger)for(let i of r.split(/\r?\n/))i.length>0&&this.logger.info(`[${e.agentId}] ${i}`);else process.stderr.write(`[${e.agentId}] ${r}`)}),n.on("error",r=>{let i=this.formatFailure(r.message);this.writeLog(`--- spawn error: ${r.message} time=${new Date().toISOString()} ---
|
|
217
237
|
`),this.connection.fail(new Error(i))}),n.on("exit",(r,i)=>{if(this.exited=!0,this.writeLog(`--- exit code=${r} signal=${i} ${this.killed?"(after kill) ":""}time=${new Date().toISOString()} ---
|
|
218
238
|
`),this.fileLog?.end(),this.fileLog=void 0,this.killed)this.logger?.info(`agent ${e.agentId} pid=${n.pid} exited after kill code=${r} signal=${i}`);else{let o=`agent ${e.agentId} exited before responding (code=${r} signal=${i})`;this.connection.fail(new Error(this.formatFailure(o))),this.logger?.warn(`agent ${e.agentId} pid=${n.pid} exited unexpectedly code=${r} signal=${i}`)}for(let o of this.exitHandlers)o(r,i)})}writeLog(e){if(this.fileLog)try{this.fileLog.write(e)}catch{}}formatFailure(e){let n=this.stderrTail.trim();return n?`${e}
|
|
219
|
-
stderr: ${n}`:e}static spawn(e){let n={...process.env,...e.plan.env,...e.extraEnv??{}},s=
|
|
239
|
+
stderr: ${n}`:e}static spawn(e){let n={...process.env,...e.plan.env,...e.extraEnv??{}},s=ey(e.plan.command,e.plan.args,{cwd:e.cwd,env:n,stdio:["pipe","pipe","pipe"],detached:!0});return s.unref(),new t(e,s)}onExit(e){this.exitHandlers.push(e)}isAlive(){return!this.exited}async kill(e="SIGTERM"){this.exited||(this.killed=!0,this.writeLog(`--- kill requested signal=${e} time=${new Date().toISOString()} ---
|
|
220
240
|
`),this.logger?.info(`agent ${this.agentId} pid=${this.child.pid} kill requested signal=${e}`),await this.connection.close().catch(()=>{}),this.signalProcessGroup(e),await this.waitForExit(this.killEscalationMs),!this.exited&&(this.writeLog(`--- kill escalating signal=SIGKILL time=${new Date().toISOString()} ---
|
|
221
|
-
`),this.logger?.warn(`agent ${this.agentId} pid=${this.child.pid} did not exit after ${e}; sending SIGKILL`),this.signalProcessGroup("SIGKILL"),await this.waitForExit(this.killEscalationMs)))}signalProcessGroup(e){let n=this.child.pid;if(n!==void 0)try{process.kill(-n,e)}catch{try{this.child.kill(e)}catch{}}}waitForExit(e){return this.exited?Promise.resolve():new Promise(n=>{let s=setTimeout(()=>{this.child.off("exit",r),n()},e),r=()=>{clearTimeout(s),n()};this.child.once("exit",r)})}},
|
|
222
|
-
`,
|
|
223
|
-
`),n)}function
|
|
224
|
-
`);for(;n.length>0;){let s=
|
|
225
|
-
`);if(s.length<=e)return s;n.shift()}return
|
|
241
|
+
`),this.logger?.warn(`agent ${this.agentId} pid=${this.child.pid} did not exit after ${e}; sending SIGKILL`),this.signalProcessGroup("SIGKILL"),await this.waitForExit(this.killEscalationMs)))}signalProcessGroup(e){let n=this.child.pid;if(n!==void 0)try{process.kill(-n,e)}catch{try{this.child.kill(e)}catch{}}}waitForExit(e){return this.exited?Promise.resolve():new Promise(n=>{let s=setTimeout(()=>{this.child.off("exit",r),n()},e),r=()=>{clearTimeout(s),n()};this.child.once("exit",r)})}},ny=2e3;function sy(t){try{let e=P.agentLogFile(t);Yi.mkdirSync(ru.dirname(e),{recursive:!0});let n=Yi.createWriteStream(e,{flags:"a"});return n.on("error",()=>{}),n}catch{return}}import*as fs from"fs/promises";import*as uo from"os";import*as Vr from"path";import{customAlphabet as mw}from"nanoid";Yt();od();ue();os();import*as dn from"fs/promises";import{z as Qt}from"zod";var Uy=Qt.object({version:Qt.literal(1),agentId:Qt.string(),upstreamSessionId:Qt.string(),deletedAt:Qt.string(),upstreamUpdatedAt:Qt.string().optional(),cwd:Qt.string().optional(),title:Qt.string().optional(),reason:Qt.enum(["user","expired"]).optional(),interactive:Qt.boolean().optional()}),to=class{async add(e){let n={version:1,...e};await ht(P.tombstoneFile(e.agentId,e.upstreamSessionId),n,{mode:384})}async has(e,n){try{return await dn.access(P.tombstoneFile(e,n)),!0}catch{return!1}}async read(e,n){let s=P.tombstoneFile(e,n),r=await At(s);if(r===void 0)return await this.has(e,n)?{version:1,agentId:e,upstreamSessionId:n,deletedAt:new Date(0).toISOString()}:void 0;try{return Uy.parse(r)}catch{return{version:1,agentId:e,upstreamSessionId:n,deletedAt:new Date(0).toISOString()}}}async remove(e,n){try{await dn.unlink(P.tombstoneFile(e,n))}catch(s){if(s.code!=="ENOENT")throw s}try{await dn.rmdir(P.tombstoneAgentDir(e))}catch(s){let r=s;if(r.code!=="ENOENT"&&r.code!=="ENOTEMPTY")throw s}}async list(e){if(e!==void 0)return this.listForAgent(e);let n;try{n=await dn.readdir(P.tombstonesDir())}catch(r){if(r.code==="ENOENT")return[];throw r}let s=[];for(let r of n){let i;try{i=decodeURIComponent(r)}catch{continue}s.push(...await this.listForAgent(i))}return s}async listForAgent(e){let n;try{n=await dn.readdir(P.tombstoneAgentDir(e))}catch(r){if(r.code==="ENOENT")return[];throw r}let s=[];for(let r of n){let i;try{i=decodeURIComponent(r)}catch{continue}let o=await this.read(e,i);o&&s.push(o)}return s}};function Su(t,e){return e===void 0?!1:t.upstreamUpdatedAt===void 0?!0:e>t.upstreamUpdatedAt}import*as _u from"fs/promises";dt();Lt();Zi();var ku=`[older history truncated]
|
|
242
|
+
`,Wy=["file_path","path","command","pattern","query"];function xu(t,e={}){let n=e.maxChars??4e5,s=[],r="",i=()=>{r.length!==0&&(s.push(`Assistant: ${r}`),r="")};for(let o of t){if(o.method!=="session/update")continue;let d=o.params?.update;if(!d||typeof d.sessionUpdate!="string")continue;let c=d.sessionUpdate;if(c==="prompt_received"){i();let l=Vy(d.prompt).trim();l.length>0&&s.push(`User: ${l}`)}else if(c==="agent_message_chunk"){let l=Yy(d.content);l.length>0&&(r+=l)}else c==="tool_call"?(i(),s.push(zy(d))):c==="turn_complete"&&i()}return i(),Gy(s.join(`
|
|
243
|
+
`),n)}function zy(t){let e=Jy(t),n=Ky(t.rawInput);return n.length===0?`Tool: ${e}`:`Tool: ${e}(${n.join(", ")})`}function Jy(t){return typeof t.name=="string"&&t.name.length>0?t.name:typeof t.title=="string"&&t.title.length>0?t.title:"(unnamed)"}function Ky(t){if(!t||typeof t!="object"||Array.isArray(t))return[];let e=t,n=[];for(let s of Wy){let r=e[s];typeof r=="string"&&r.length>0&&n.push(`${s}=${Qy(r,200)}`)}return n}function Vy(t){return typeof t=="string"?t:Array.isArray(t)?t.map(e=>{if(e&&typeof e=="object"){let n=e.text;if(typeof n=="string")return n}return""}).join(""):""}function Yy(t){if(!t||typeof t!="object")return"";let e=t.text;return typeof e=="string"?e:""}function Qy(t,e){return t.length<=e?t:t.slice(0,e-1)+"\u2026"}function Gy(t,e){if(t.length<=e)return t;let n=t.split(`
|
|
244
|
+
`);for(;n.length>0;){let s=ku+n.join(`
|
|
245
|
+
`);if(s.length<=e)return s;n.shift()}return ku}var Xy=12e4;async function Cu(t){let e=t.timeoutMs??Xy,n,s,r=!1;try{let i=(async()=>{n=_n.spawn({agentId:t.agentId,cwd:t.cwd,plan:t.plan,logger:t.logger});let o=await n.connection.request("initialize",{protocolVersion:yt,clientCapabilities:{},clientInfo:{name:"hydra-synopsis",version:me}}),a=await n.connection.request("session/new",{cwd:t.cwd,mcpServers:[]}),d=a.sessionId;if(typeof d!="string"){t.logger?.warn(`synopsis: agent ${t.agentId} returned non-string sessionId from session/new`);return}if(t.modelId){let g=ew(a);if(g.size===0||g.has(t.modelId))try{await n.connection.request("session/set_model",{sessionId:d,modelId:t.modelId})}catch(h){t.logger?.warn(`synopsis: agent ${t.agentId} rejected set_model ${JSON.stringify(t.modelId)}: ${h.message}; continuing on default`)}else t.logger?.warn(`synopsis: model ${JSON.stringify(t.modelId)} not advertised by agent ${t.agentId} (have [${[...g].join(", ")}]); continuing on default`)}let c=[];n.connection.onNotification("session/update",g=>{let h=Zy(g);h.length>0&&c.push(h)});let l=xu(t.history,{maxChars:t.maxTranscriptChars}),f=l.length>0?`${l}
|
|
226
246
|
|
|
227
|
-
${Za}`:Za;await n.connection.request("session/prompt",{sessionId:d,prompt:[{type:"text",text:f}]});let u=c.join(""),p=
|
|
247
|
+
${Za}`:Za;await n.connection.request("session/prompt",{sessionId:d,prompt:[{type:"text",text:f}]});let u=c.join(""),p=Iu(u);return p||t.logger?.warn(`synopsis: agent ${t.agentId} reply did not parse as snapshot JSON (replyLen=${u.length} preview=${JSON.stringify(u.slice(0,200))})`),p})();return await new Promise((o,a)=>{s=setTimeout(()=>{r=!0,t.logger?.warn(`synopsis: agent ${t.agentId} timed out after ${e}ms`),o(void 0)},e),s.unref?.(),i.then(d=>{s&&clearTimeout(s),r||o(d)},d=>{s&&clearTimeout(s),r||a(d)})})}catch(i){t.logger?.warn(`synopsis: agent ${t.agentId} failed: ${i.message}`);return}finally{s&&clearTimeout(s),n&&await n.kill().catch(()=>{})}}function Zy(t){if(!t||typeof t!="object")return"";let e=t.update;if(!e||typeof e!="object")return"";let n=e;if(n.sessionUpdate!=="agent_message_chunk")return"";let s=n.content;return s&&typeof s.text=="string"?s.text:""}function ew(t){let e=new Set;Au(e,t.availableModels);let n=t.models;return n&&typeof n=="object"&&!Array.isArray(n)&&Au(e,n.availableModels),e}function Au(t,e){if(Array.isArray(e)){for(let n of e)if(n&&typeof n=="object"){let s=n.modelId??n.value??n.id;typeof s=="string"&&s.length>0&&t.add(s)}}}cd();ue();var tw=2,so=class{constructor(e){this.opts=e;this.maxConcurrent=e.maxConcurrent??tw}opts;queued=new Set;inflight=new Map;stopped=!1;maxConcurrent;schedule(e){this.stopped||this.queued.has(e)||this.inflight.has(e)||(this.queued.add(e),this.drain())}size(){return{queued:this.queued.size,inflight:this.inflight.size}}async flush(e){let n=Date.now()+e;for(;this.queued.size>0||this.inflight.size>0;){let s=n-Date.now();if(s<=0)return;let r=[...this.inflight.values()];if(r.length===0){await new Promise(i=>{setTimeout(i,25).unref?.()});continue}await Promise.race([Promise.race(r),new Promise(i=>{setTimeout(i,s).unref?.()})])}}async shutdown(){this.stopped=!0,this.queued.clear(),await Promise.allSettled([...this.inflight.values()])}drain(){if(!this.stopped)for(;this.inflight.size<this.maxConcurrent&&this.queued.size>0;){let e=this.queued.values().next().value;if(!e)return;this.queued.delete(e);let n=this.runOne(e).finally(()=>{this.inflight.delete(e),this.drain()});this.inflight.set(e,n)}}async runOne(e){try{let n=await this.opts.store.read(e);if(!n){this.opts.logger?.info(`synopsis: session ${e} record missing; skipping`);return}let s=await this.opts.histories.load(e),r=n.summarizedThroughEntry;if(r!==void 0&&s.length<=r){this.opts.logger?.info(`synopsis: skip ${e} (history unchanged at ${s.length})`);return}let i=this.opts.synopsisAgent??n.agentId,o=await this.opts.registry.getAgent(i);if(!o){this.opts.logger?.warn(`synopsis: agent ${i} not in registry for session ${e}; skipping`);return}let a=await $n(o,[],{npmRegistry:this.opts.npmRegistry}),d=this.opts.synopsisModel,c=P.sessionDir(e);await _u.mkdir(c,{recursive:!0}).catch(()=>{}),this.opts.logger?.info(`synopsis: start sessionId=${e} agentId=${i} historyLen=${s.length} model=${JSON.stringify(d??"(default)")} cwd=${c}`);let l=await Cu({agentId:i,cwd:c,plan:a,history:s,modelId:d,logger:this.opts.logger,timeoutMs:this.opts.generateTimeoutMs});if(!l){this.opts.logger?.warn(`synopsis: sessionId=${e} no parseable result; not persisting`);return}l.title&&await this.opts.persistTitle(e,l.title);let f=nw(l.synopsis,s);f&&sw(f)?(await this.opts.persistSynopsis(e,f,s.length),this.opts.logger?.info(`synopsis: persisted sessionId=${e} title=${JSON.stringify(!!l.title)} fields=${rw(f)}`)):l.title&&this.opts.logger?.info(`synopsis: persisted title only sessionId=${e}`)}catch(n){this.opts.logger?.warn(`synopsis: sessionId=${e} failed: ${n.message}`)}}};function nw(t,e){let n=Pu(e),s=Eu(e);return t?{...t,files_touched:n.length>0?n:t.files_touched,tools_used:s.length>0?s:t.tools_used}:n.length===0&&s.length===0?void 0:{files_touched:n.length>0?n:void 0,tools_used:s.length>0?s:void 0}}function sw(t){return!!(t.goal&&t.goal.trim().length>0||t.outcome&&t.outcome.trim().length>0||t.files_touched&&t.files_touched.length>0||t.tools_used&&t.tools_used.length>0||t.rejected_approaches&&t.rejected_approaches.length>0||t.open_threads&&t.open_threads.length>0)}function rw(t){let e=[];return t.goal&&e.push("goal"),t.outcome&&e.push("outcome"),t.files_touched&&t.files_touched.length>0&&e.push(`files=${t.files_touched.length}`),t.tools_used&&t.tools_used.length>0&&e.push(`tools=${t.tools_used.length}`),t.rejected_approaches&&t.rejected_approaches.length>0&&e.push(`rejected=${t.rejected_approaches.length}`),t.open_threads&&t.open_threads.length>0&&e.push(`open=${t.open_threads.length}`),`[${e.join(",")}]`}ue();import*as it from"fs/promises";function Fu(t){return t==="summary"?"summary":"inline"}var ld=256;function Ou(t,e){return e!=="summary"?t:t.map(iw)}function iw(t){if(t.method!=="session/update")return t;let e=t.params;if(!e||typeof e!="object"||Array.isArray(e))return t;let n=e,s=n.update;if(!s||typeof s!="object"||Array.isArray(s))return t;let r=s;if(r.sessionUpdate!=="tool_call"&&r.sessionUpdate!=="tool_call_update")return t;let i={...r};Array.isArray(r.content)&&(i.content=r.content.map(Lu));let o=r.rawOutput;if(o&&typeof o=="object"&&!Array.isArray(o)){let a=o,d={};a.error!==void 0&&(d.error=ud(a.error)),a.metadata!==void 0&&(d.metadata=a.metadata),i.rawOutput=d}return{...t,params:{...n,update:i}}}function ow(t){return!!t&&typeof t=="object"&&!Array.isArray(t)&&t.type==="diff"}function Lu(t){if(ow(t)){let s=t,r={type:"diff",oldText:"",newText:""};return typeof s.path=="string"&&(r.path=s.path),r}if(!t||typeof t!="object"||Array.isArray(t))return t;let e=t,n={...e};return typeof e.text=="string"&&(n.text=ud(e.text)),typeof e.content=="string"?n.content=ud(e.content):e.content&&typeof e.content=="object"&&(n.content=Lu(e.content)),n}function ud(t){if(typeof t=="string"&&t.length>ld){let e=t.length-ld;return`${t.slice(0,ld)}\u2026[+${e} chars omitted from summary export]`}return t}var aw=2048;function Bu(t){let e=new Set,n=s=>{if(Nu(s)){e.add(s.__hydraBlob);return}if(Array.isArray(s)){for(let r of s)n(r);return}if(s&&typeof s=="object")for(let r of Object.values(s))n(r)};for(let s of t)n(s.params);return e}function Nu(t){return!!t&&typeof t=="object"&&!Array.isArray(t)&&typeof t.__hydraBlob=="string"}function dw(t){if(t.method!=="session/update")return!1;let e=t.params;if(!e||typeof e!="object"||Array.isArray(e))return!1;let n=e.update;if(!n||typeof n!="object"||Array.isArray(n))return!1;let s=n.sessionUpdate;return s==="tool_call"||s==="tool_call_update"}async function md(t,e){if(!dw(t))return t;let n=t.params,s=n.update,r=await fd(s,e);return{...t,params:{...n,update:r}}}async function fd(t,e){if(typeof t=="string"){if(t.length<=aw)return t;let n=await e(t);return n===null?t:{__hydraBlob:n,bytes:t.length}}if(Array.isArray(t)){let n=[];for(let s of t)n.push(await fd(s,e));return n}if(t&&typeof t=="object"){let n={};for(let[s,r]of Object.entries(t))n[s]=await fd(r,e);return n}return t}async function Du(t,e){let n=t.params;if(!n||typeof n!="object"||Array.isArray(n))return t;let s=await pd(n,e);return s===n?t:{...t,params:s}}async function pd(t,e){if(Nu(t))return await e(t.__hydraBlob)??"";if(Array.isArray(t)){let n=!1,s=[];for(let r of t){let i=await pd(r,e);i!==r&&(n=!0),s.push(i)}return n?s:t}if(t&&typeof t=="object"){let n=!1,s={};for(let[r,i]of Object.entries(t)){let o=await pd(i,e);o!==i&&(n=!0),s[r]=o}return n?s:t}return t}var qr=/^[A-Za-z0-9_-]+$/,cw=1e3,ro=class{writeQueues=new Map;maxEntries;constructor(e={}){this.maxEntries=e.maxEntries??cw}async append(e,n){if(qr.test(e))return this.enqueue(e,async()=>{await it.mkdir(P.sessionDir(e),{recursive:!0});let s=await md(n,i=>Ba(e,i)),r=JSON.stringify(s)+`
|
|
228
248
|
`;await it.appendFile(P.historyFile(e),r,{encoding:"utf8",mode:384})})}async rewrite(e,n){if(qr.test(e))return this.enqueue(e,async()=>{await it.mkdir(P.sessionDir(e),{recursive:!0});let s=[];for(let i of n)s.push(await md(i,o=>Ba(e,o)));let r=s.length===0?"":s.map(i=>JSON.stringify(i)).join(`
|
|
229
249
|
`)+`
|
|
230
250
|
`;await it.writeFile(P.historyFile(e),r,{encoding:"utf8",mode:384})})}async compact(e,n){if(qr.test(e))return this.enqueue(e,async()=>{let s;try{s=await it.readFile(P.historyFile(e),"utf8")}catch(o){if(o.code==="ENOENT")return;throw o}let r=s.split(`
|
|
231
251
|
`).filter(o=>o.length>0);if(r.length<=n)return;let i=r.slice(-n);await it.writeFile(P.historyFile(e),i.join(`
|
|
232
252
|
`)+`
|
|
233
253
|
`,{encoding:"utf8",mode:384})})}async load(e,n={}){if(!qr.test(e))return[];let s=(n.tools??"inline")==="inline",r=this.writeQueues.get(e);r&&await r;let i;try{i=await it.readFile(P.historyFile(e),"utf8")}catch(f){if(f.code==="ENOENT")return[];throw f}let o=[];for(let f of i.split(`
|
|
234
|
-
`)){if(f.length===0)continue;let u;try{u=JSON.parse(f)}catch{continue}if(!u||typeof u!="object"||Array.isArray(u))continue;let p=u;typeof p.method=="string"&&typeof p.recordedAt=="number"&&o.push({method:p.method,params:p.params,recordedAt:p.recordedAt})}let a=o.length>this.maxEntries?o.slice(-this.maxEntries):o;if(!s)return a;let d=new Map,c=async f=>{let u=d.get(f);if(u!==void 0)return u;let p=await Ui(e,f);return d.set(f,p),p},l=[];for(let f of a)l.push(await
|
|
235
|
-
`),await i.kill().catch(()=>{}),this.doResurrectFromImport(e)}if(e.pendingHistorySync===!0)this.clearPendingHistorySync(e.hydraSessionId).catch(()=>{});else{let h=i.connection.drainBuffered("session/update");this.logger?.info(`resurrect: drain1 dropped ${h} buffered session/update(s) for sessionId=${e.hydraSessionId}`)}let d=Ju(a??{}),c=e.agentModes??qu(zu(a??{}));this.logger?.info(`resurrect: sessionId=${e.hydraSessionId} persistedMode=${JSON.stringify(e.currentMode)} agentReportedMode=${JSON.stringify(d)} advertisedModes=${JSON.stringify(c?.map(h=>h.id))}`);let l=await Ku({agent:i,upstreamSessionId:e.upstreamSessionId,persistedMode:e.currentMode,agentReportedMode:d,advertisedModes:c,logger:this.logger});this.logger?.info(`resurrect: effectiveMode=${JSON.stringify(l)} for sessionId=${e.hydraSessionId}`);let f=ju(a??{}),u=qu(Wu(a??{}))??e.agentModels;if(this.logger?.info(`resurrect: sessionId=${e.hydraSessionId} persistedModel=${JSON.stringify(e.currentModel)} agentReportedModel=${JSON.stringify(f)} advertisedModels=${JSON.stringify(u?.map(h=>h.modelId))}`),e.pendingHistorySync!==!0){let h=i.connection.drainBuffered("session/update");this.logger?.info(`resurrect: drain2 (post-mode-restore) dropped ${h} buffered session/update(s) for sessionId=${e.hydraSessionId}`)}let p=await Vu({agent:i,upstreamSessionId:e.upstreamSessionId,persistedModel:e.currentModel,agentReportedModel:f,logger:this.logger});if(e.pendingHistorySync!==!0){let h=i.connection.drainBuffered("session/update");this.logger?.info(`resurrect: drain3 (post-model-restore) dropped ${h} buffered session/update(s) for sessionId=${e.hydraSessionId}`)}let g=new Ys({sessionId:e.hydraSessionId,cwd:e.cwd,agentId:e.agentId,agent:i,upstreamSessionId:e.upstreamSessionId,agentMeta:a?._meta,agentCapabilities:o,title:e.title,agentArgs:e.agentArgs,idleTimeoutMs:this.idleTimeoutMs,logger:this.logger,spawnReplacementAgent:h=>this.bootstrapAgent({...h,mcpServers:e.mcpServers??[]}),listSessions:()=>this.list(),availableAgents:()=>this.agentCatalog,historyStore:this.histories,historyMaxEntries:this.sessionHistoryMaxEntries,currentModel:p,currentMode:l,currentUsage:e.currentUsage,agentCommands:e.agentCommands,agentModes:c,agentModels:u,firstPromptSeeded:!!e.title,createdAt:e.createdAt?new Date(e.createdAt).getTime():void 0,originatingClient:e.originatingClient,interactive:e.interactive,priority:e.priority,forkedFromSessionId:e.forkedFromSessionId,forkedFromMessageId:e.forkedFromMessageId,extensionCommands:this.extensionCommands,scheduleSynopsis:()=>this.synopsisCoordinator.schedule(g.sessionId)});return await this.attachManagerHooks(g),g}async doResurrectFromImport(e){let n=await this.resolveResurrectCwd(e.cwd),s=await this.bootstrapAgent({agentId:e.agentId,cwd:n,agentArgs:e.agentArgs,mcpServers:e.mcpServers??[],onInstallProgress:e.onInstallProgress,model:e.currentModel}),r=e.agentModes??s.initialModes,i=await Ku({agent:s.agent,upstreamSessionId:s.upstreamSessionId,persistedMode:e.currentMode,agentReportedMode:s.initialMode,advertisedModes:r,logger:this.logger}),o=e.agentModels??s.initialModels,a=await Vu({agent:s.agent,upstreamSessionId:s.upstreamSessionId,persistedModel:e.currentModel,agentReportedModel:s.initialModel,logger:this.logger});s.agent.connection.drainBuffered("session/update");let d=new Ys({sessionId:e.hydraSessionId,cwd:n,agentId:e.agentId,agent:s.agent,upstreamSessionId:s.upstreamSessionId,agentMeta:s.agentMeta,agentCapabilities:s.agentCapabilities,title:e.title,agentArgs:e.agentArgs,idleTimeoutMs:this.idleTimeoutMs,logger:this.logger,spawnReplacementAgent:c=>this.bootstrapAgent({...c,mcpServers:e.mcpServers??[]}),listSessions:()=>this.list(),availableAgents:()=>this.agentCatalog,historyStore:this.histories,historyMaxEntries:this.sessionHistoryMaxEntries,currentModel:a,currentMode:i,currentUsage:e.currentUsage,agentCommands:e.agentCommands,agentModes:r,agentModels:o,firstPromptSeeded:!!e.title,createdAt:e.createdAt?new Date(e.createdAt).getTime():void 0,originatingClient:e.originatingClient,interactive:e.interactive,priority:e.priority,forkedFromSessionId:e.forkedFromSessionId,forkedFromMessageId:e.forkedFromMessageId,extensionCommands:this.extensionCommands,scheduleSynopsis:()=>this.synopsisCoordinator.schedule(d.sessionId)});return await this.attachManagerHooks(d),d.seedFromImport().catch(()=>{}),d}async dirExists(e){try{return(await us.stat(e)).isDirectory()}catch{return!1}}async reapIfOrphanedNonInteractive(e){let n=this.sessions.get(e);!n||n.attachedCount>0||n.interactive!==!0&&(this.logger?.info(`reaping orphaned non-interactive session ${e} (agent killed, cold record kept)`),await n.close({deleteRecord:!1}).catch(()=>{}))}async resolveResurrectCwd(e){return await this.dirExists(e)?e:Ft(this.defaultCwd)}async syncFromAgent(e){let n=await this.registry.getAgent(e);if(!n){let p=new Error(`agent ${e} not found in registry`);throw p.code=B.AgentNotInstalled,p}let s=await $n(n,[],{npmRegistry:this.npmRegistry}),r=this.spawner({agentId:e,cwd:uo.homedir(),plan:s}),i;try{i=await r.connection.request("initialize",{protocolVersion:yt,clientCapabilities:{},clientInfo:{name:"hydra",version:me}})}catch(p){throw await r.kill().catch(()=>{}),p}if((i.agentCapabilities??{}).sessionCapabilities?.list===void 0)throw await r.kill().catch(()=>{}),new Error(`agent ${e} does not advertise sessionCapabilities.list; cannot sync`);let a;try{a=await this.collectAgentSessions(r)}catch(p){throw await r.kill().catch(()=>{}),p}await r.kill().catch(()=>{});let d=new Set;for(let p of this.sessions.values())d.add(`${p.agentId}::${p.upstreamSessionId}`);let c=await this.store.list().catch(()=>[]);for(let p of c)d.add(`${p.agentId}::${p.upstreamSessionId}`);let l=P.sessionsDir(),f=[],u=0;for(let p of a){let g=`${e}::${p.sessionId}`;if(d.has(g)){u+=1;continue}if(hw(p.cwd,l)){u+=1;continue}let h=await this.tombstones.read(e,p.sessionId).catch(()=>{});if(h){if(!Iu(h,p.updatedAt)){u+=1;continue}await this.tombstones.remove(e,p.sessionId).catch(()=>{}),this.logger?.info(`syncFromAgent: resurrecting tombstoned ${e}/${p.sessionId} (upstream updatedAt advanced past ${h.upstreamUpdatedAt??"<unset>"})`)}d.add(g);let w=`${an}${ao()}`,v=new Date().toISOString(),b=p.updatedAt??v,x={sessionId:w,lineageId:Ur(),upstreamSessionId:p.sessionId,agentId:e,cwd:p.cwd,pendingHistorySync:!0,interactive:!0,createdAt:b,updatedAt:b};p.title!==void 0&&(x.title=p.title);let C=id(x);await this.store.write(C),f.push({version:1,...C})}return{synced:f,skipped:u}}async collectAgentSessions(e){let n=[],s;for(let r=0;r<100;r+=1){let i={};s!==void 0&&(i.cursor=s);let o=await e.connection.request("session/list",i),a=Array.isArray(o.sessions)?o.sessions:[];for(let d of a){if(typeof d.sessionId!="string"||typeof d.cwd!="string")continue;let c={sessionId:d.sessionId,cwd:d.cwd};typeof d.title=="string"&&(c.title=d.title),typeof d.updatedAt=="string"&&(c.updatedAt=d.updatedAt),n.push(c)}if(typeof o.nextCursor!="string"||o.nextCursor.length===0)break;s=o.nextCursor}return n}async applySeedModel(e,n,s,r){try{return await e.connection.request("session/set_model",{sessionId:n,modelId:s}),this.logger?.info(`${r}: session/set_model accepted`),!0}catch(i){return this.logger?.warn(`${r} rejected by agent (${i.message}); session will use the agent's own default`),!1}}async bootstrapAgent(e){let n=await this.registry.getAgent(e.agentId);if(!n){let i=new Error(`agent ${e.agentId} not found in registry`);throw i.code=B.AgentNotInstalled,i}let s=await $n(n,e.agentArgs??[],{npmRegistry:this.npmRegistry,onInstallProgress:e.onInstallProgress}),r=this.spawner({agentId:e.agentId,cwd:e.cwd,plan:s});try{let o=(await r.connection.request("initialize",{protocolVersion:yt,clientCapabilities:{},clientInfo:{name:"hydra",version:me}})).agentCapabilities,a=await r.connection.request("session/new",{cwd:e.cwd,mcpServers:e.mcpServers??[]}),d=a.sessionId;if(typeof d!="string")throw new Error(`agent ${e.agentId} returned a non-string sessionId from session/new`);let c=ju(a),l=Wu(a),f=e.model??this.defaultModels[e.agentId];if(f&&f!==c){let g=Js(f,l),h=e.model!==void 0?`model=${JSON.stringify(f)}`:`defaultModels[${e.agentId}]=${JSON.stringify(f)}`;if(g.kind==="exact"||g.kind==="none")await this.applySeedModel(r,d,f,h)&&(c=f);else if(g.kind==="resolved")(g.modelId===c||await this.applySeedModel(r,d,g.modelId,`${h} resolved to ${JSON.stringify(g.modelId)}`))&&(c=g.modelId);else if(g.kind==="ambiguous")this.logger?.warn(`${h} is ambiguous (trailing-segment matches [${g.candidates.join(", ")}]); skipping session/set_model, session will use ${JSON.stringify(c)}`);else{let w=l.map(v=>v.modelId).join(", ");this.logger?.warn(`${h} not in agent's availableModels ([${w}]); skipping session/set_model, session will use ${JSON.stringify(c)}`)}}let u=zu(a),p=Ju(a);return{agent:r,upstreamSessionId:d,agentMeta:a._meta,agentCapabilities:o,initialModel:c,initialModels:l.length>0?l:void 0,initialModes:u.length>0?u:void 0,initialMode:p}}catch(i){throw await r.kill().catch(()=>{}),i}}async attachManagerHooks(e){e.onClose(({deleteRecord:n})=>{if(this.sessions.delete(e.sessionId),this.invalidateListCache(),n){if(e.upstreamSessionId){let s=co({interactive:e.interactive,...e.originatingClient?{originatingClient:e.originatingClient}:{}},!0);this.tombstones.add({agentId:e.agentId,upstreamSessionId:e.upstreamSessionId,deletedAt:new Date().toISOString(),upstreamUpdatedAt:new Date(e.updatedAt).toISOString(),cwd:e.cwd,title:e.title,reason:"user",...s!==void 0?{interactive:s}:{}}).catch(()=>{})}this.store.delete(e.sessionId).catch(()=>{}),this.histories.delete(e.sessionId).catch(()=>{});return}e.firstPromptSeeded&&this.synopsisOnClose&&this.synopsisCoordinator.schedule(e.sessionId)}),e.onTitleChange(n=>{this.persistTitle(e.sessionId,n).catch(()=>{})}),e.onPriorityChange(n=>{this.persistPriority(e.sessionId,n).catch(()=>{})}),e.onAgentChange(({agentId:n,upstreamSessionId:s})=>{this.persistAgentChange(e.sessionId,n,s).catch(()=>{})}),e.onModelChange(n=>{this.persistSnapshot(e.sessionId,{currentModel:n}).catch(()=>{})}),e.onModeChange(n=>{this.persistSnapshot(e.sessionId,{currentMode:n}).catch(()=>{})}),e.onInteractiveChange(n=>{this.persistSnapshot(e.sessionId,{interactive:n}).catch(()=>{})}),e.onUsageChange(n=>{this.persistSnapshot(e.sessionId,{currentUsage:Qu(n)}).catch(()=>{})}),e.onAgentCommandsChange(n=>{this.persistSnapshot(e.sessionId,{agentCommands:n.map(s=>({name:s.name,...s.description!==void 0?{description:s.description}:{}}))}).catch(()=>{})}),e.onAgentModesChange(n=>{this.persistSnapshot(e.sessionId,{agentModes:n.map(s=>({id:s.id,...s.name!==void 0?{name:s.name}:{},...s.description!==void 0?{description:s.description}:{}}))}).catch(()=>{})}),e.onAgentModelsChange(n=>{this.persistSnapshot(e.sessionId,{agentModels:n.map(s=>({modelId:s.modelId,...s.name!==void 0?{name:s.name}:{},...s.description!==void 0?{description:s.description}:{}}))}).catch(()=>{})}),this.sessions.set(e.sessionId,e),this.invalidateListCache(),await this.enqueueMetaWrite(e.sessionId,async()=>{let n=await this.store.read(e.sessionId),s=gw(e,n);await this.store.write(s)}).catch(()=>{})}async getHistory(e){if(this.sessions.has(e))return this.histories.load(e).catch(()=>[]);if(await this.store.read(e))return this.histories.load(e).catch(()=>[])}async loadHistory(e){return this.histories.load(e)}async loadToolBlob(e,n){return Ui(e,n)}async loadFromDisk(e){let n=await this.store.read(e);if(!n)return;let s=n.title;return s||(s=await this.deriveTitleFromHistory(e)),{hydraSessionId:n.sessionId,upstreamSessionId:n.upstreamSessionId,agentId:n.agentId,cwd:n.cwd,title:s,synopsis:n.synopsis,summarizedThroughEntry:n.summarizedThroughEntry,agentArgs:n.agentArgs,currentModel:n.currentModel,currentMode:n.currentMode,currentUsage:yw(n.currentUsage?{...n.currentUsage,cumulativeCost:(n.currentUsage.cumulativeCost??0)+(n.currentUsage.costAmount??0),costAmount:void 0}:void 0),agentCommands:n.agentCommands,agentModes:n.agentModes,agentModels:n.agentModels,createdAt:n.createdAt,pendingHistorySync:n.pendingHistorySync,originatingClient:n.originatingClient,interactive:n.interactive,priority:n.priority,forkedFromSessionId:n.forkedFromSessionId,forkedFromMessageId:n.forkedFromMessageId}}async clearPendingHistorySync(e){await this.enqueueMetaWrite(e,async()=>{let n=await this.store.read(e);if(!n||n.pendingHistorySync!==!0)return;let s={...n};delete s.pendingHistorySync,await this.store.write(s)})}async deriveTitleFromHistory(e){let n=await this.histories.load(e).catch(()=>[]);for(let s of n){let r=s.params;if(r?.update?.sessionUpdate!=="prompt_received")continue;let i=Vs(r.update.prompt),o=Xa(i,200);if(o)return o}}get(e){return this.sessions.get(e)}liveSessions(){return this.sessions.values()}activeAgentVersions(){let e=new Map;for(let n of this.sessions.values()){let s=n.agent.agentId,r=n.agent.version,i=e.get(s);i||(i=new Set,e.set(s,i)),i.add(r)}return e}async resolveCanonicalId(e){if(this.sessions.has(e)||await this.store.read(e))return e;if(e.startsWith(an))return;let n=an+e;if(this.sessions.has(n)||await this.store.read(n))return n}require(e){let n=this.sessions.get(e);if(!n){let s=new Error(`session ${e} not found`);throw s.code=B.SessionNotFound,s}return n}liveListEntry(e){return{sessionId:e.sessionId,upstreamSessionId:e.upstreamSessionId,cwd:e.cwd,title:e.title,agentId:e.agentId,currentModel:e.currentModel,currentUsage:e.currentUsage,parentSessionId:e.parentSessionId,forkedFromSessionId:e.forkedFromSessionId,forkedFromMessageId:e.forkedFromMessageId,originatingClient:e.originatingClient,interactive:e.interactive,updatedAt:new Date(e.updatedAt).toISOString(),attachedClients:e.attachedCount,status:"live",busy:e.turnStartedAt!==void 0,awaitingInput:e.awaitingInput}}async list(e={}){let n=`${e.cwd??""}|${e.includeNonInteractive?"1":"0"}`,s=Date.now(),r=this.listCache.get(n);if(r&&r.expiresAt>s)return r.promise;let i=this.listUncached(e);return this.listCache.set(n,{expiresAt:s+t.LIST_CACHE_TTL_MS,promise:i}),i.catch(()=>{let o=this.listCache.get(n);o&&o.promise===i&&this.listCache.delete(n)}),i}invalidateListCache(){this.listCache.clear()}async listUncached(e={}){let n=[],s=new Set,r=o=>e.includeNonInteractive?!0:o===!0;for(let o of this.sessions.values()){if(e.cwd&&o.cwd!==e.cwd)continue;s.add(o.sessionId);let a=await yd(o.sessionId),d=co({interactive:o.interactive,...o.originatingClient?{originatingClient:o.originatingClient}:{}},a.hasContent);if(!r(d))continue;let c=a.mtime??new Date(o.updatedAt).toISOString();n.push({sessionId:o.sessionId,upstreamSessionId:o.upstreamSessionId,cwd:o.cwd,title:o.title,agentId:o.agentId,currentModel:o.currentModel,currentUsage:o.currentUsage,parentSessionId:o.parentSessionId,forkedFromSessionId:o.forkedFromSessionId,forkedFromMessageId:o.forkedFromMessageId,originatingClient:o.originatingClient,interactive:d,priority:o.priority,updatedAt:c,attachedClients:o.attachedCount,status:"live",busy:o.turnStartedAt!==void 0,awaitingInput:o.awaitingInput})}let i=await this.store.list().catch(()=>[]);for(let o of i){if(s.has(o.sessionId)||e.cwd&&o.cwd!==e.cwd)continue;let a=await yd(o.sessionId),d=co(o,a.hasContent);if(!r(d))continue;let c=a.mtime??o.updatedAt;n.push({sessionId:o.sessionId,upstreamSessionId:o.upstreamSessionId,cwd:o.cwd,title:o.title,agentId:o.agentId,currentModel:o.currentModel,currentUsage:o.currentUsage?{...o.currentUsage,costAmount:(o.currentUsage.cumulativeCost??0)+(o.currentUsage.costAmount??0)||void 0}:void 0,importedFromMachine:o.importedFromMachine,importedFromUpstreamSessionId:o.importedFromUpstreamSessionId,parentSessionId:o.parentSessionId,forkedFromSessionId:o.forkedFromSessionId,forkedFromMessageId:o.forkedFromMessageId,originatingClient:o.originatingClient,interactive:d,priority:o.priority,updatedAt:c,attachedClients:0,status:"cold",busy:!1,awaitingInput:!1})}return n.sort((o,a)=>o.updatedAt<a.updatedAt?1:-1),n}async exportBundle(e,n={}){let s=await this.store.read(e);if(!s)return;let r;if(s.lineageId)r=s;else{let c=Ur(),l={...s,lineageId:c};await this.enqueueMetaWrite(e,async()=>{let f=await this.store.read(e);f&&(f.lineageId||await this.store.write({...f,lineageId:c}))}).catch(()=>{}),r=l}let i=n.tools??"inline",o=await this.histories.load(e,i==="references"?{tools:"references"}:{}).catch(()=>[]),a=await Yu(e);if(i!=="references")return{record:r,history:o,promptHistory:a};let d={};for(let c of Lu(o)){let l=await Ml(e,c);l&&(d[c]=l.toString("base64"))}return{record:r,history:o,promptHistory:a,toolBlobs:d}}async importBundle(e,n={}){let s=await this.store.findByLineageId(e.session.lineageId);if(s){if(!n.replace){let o=new Error(`bundle already imported as ${s.sessionId}`);throw o.code=B.BundleAlreadyImported,o.existingSessionId=s.sessionId,o}let i=this.sessions.get(s.sessionId);return i&&await i.close({deleteRecord:!1}).catch(()=>{}),await this.writeImportedRecord({sessionId:s.sessionId,bundle:e,preservedCreatedAt:s.createdAt,cwd:n.cwd}),{sessionId:s.sessionId,importedFromSessionId:e.session.sessionId,replaced:!0}}let r=`${an}${ao()}`;return await this.writeImportedRecord({sessionId:r,bundle:e,cwd:n.cwd}),{sessionId:r,importedFromSessionId:e.session.sessionId,replaced:!1}}async forkSession(e,n={}){let s=await this.store.read(e);if(!s){let g=new Error(`source session not found: ${e}`);throw g.code=B.SessionNotFound,g}let r=n.agentId??s.agentId,i=r!==s.agentId;if(i&&!await this.registry.getAgent(r)){let h=new Error(`agent ${r} not found in registry`);throw h.code=B.AgentNotInstalled,h}let o=await this.histories.load(e).catch(()=>[]),a,d;if(n.forkAt!==void 0){if(a=Ga(o,n.forkAt),a<0){let g=new Error(`forkAt messageId not found in source history: ${n.forkAt}`);throw g.code=B.InvalidParams,g}d=n.forkAt}else{let g=bw(o);if(!g){let h=new Error(`source session ${e} has no completed turns to fork from`);throw h.code=B.InvalidParams,h}a=g.index,d=g.messageId}let c=o.slice(0,a+1),l=await Yu(e),f={...s,lineageId:Ur(),agentId:r,...i?{currentModel:void 0,currentMode:void 0,currentUsage:void 0,agentCommands:void 0,agentModes:void 0,agentModels:void 0}:{}},u=Kr({record:f,history:c,promptHistory:l.length>0?l:void 0,hydraVersion:me,machine:uo.hostname()}),p=`${an}${ao()}`;return await this.writeImportedRecord({sessionId:p,bundle:u,cwd:n.cwd,forkedFromSessionId:e,forkedFromMessageId:d}),{sessionId:p,forkedFromSessionId:e,forkedAt:d}}async writeImportedRecord(e){if(await this.histories.rewrite(e.sessionId,e.bundle.history),e.bundle.toolBlobs)for(let[i,o]of Object.entries(e.bundle.toolBlobs))await $l(e.sessionId,i,Buffer.from(o,"base64")).catch(()=>{});let n=new Date(e.bundle.session.updatedAt);Number.isNaN(n.getTime())||await us.utimes(P.historyFile(e.sessionId),n,n).catch(()=>{}),e.bundle.promptHistory&&e.bundle.promptHistory.length>0&&await cs(P.tuiHistoryFile(e.sessionId),e.bundle.promptHistory).catch(()=>{});let s=new Date().toISOString(),r=e.forkedFromSessionId!==void 0;await this.enqueueMetaWrite(e.sessionId,async()=>{await this.store.write({sessionId:e.sessionId,lineageId:e.bundle.session.lineageId,upstreamSessionId:"",...r?{forkedFromSessionId:e.forkedFromSessionId,forkedFromMessageId:e.forkedFromMessageId}:{importedFromSessionId:e.bundle.session.sessionId,importedFromUpstreamSessionId:e.bundle.session.upstreamSessionId,importedFromMachine:e.bundle.exportedFrom.machine},agentId:e.bundle.session.agentId,cwd:e.cwd??e.bundle.session.cwd,title:e.bundle.session.title,synopsis:e.bundle.session.synopsis,summarizedThroughEntry:e.bundle.session.summarizedThroughEntry,currentModel:e.bundle.session.currentModel,currentMode:e.bundle.session.currentMode,currentUsage:e.bundle.session.currentUsage,agentCommands:e.bundle.session.agentCommands,agentModes:e.bundle.session.agentModes,interactive:e.bundle.session.interactive,originatingClient:e.bundle.session.originatingClient,priority:e.bundle.session.priority,createdAt:e.preservedCreatedAt??s,updatedAt:e.bundle.session.updatedAt})})}async deleteRecord(e){let n=await this.store.read(e);if(!n)return!1;if(n.upstreamSessionId){let s=await yd(e),r=co(n,s.hasContent);await this.tombstones.add({agentId:n.agentId,upstreamSessionId:n.upstreamSessionId,deletedAt:new Date().toISOString(),upstreamUpdatedAt:n.updatedAt,cwd:n.cwd,title:n.title,reason:"user",...r!==void 0?{interactive:r}:{}}).catch(()=>{})}return await this.store.delete(e).catch(()=>{}),await this.histories.delete(e).catch(()=>{}),this.invalidateListCache(),!0}async hasRecord(e){return await this.store.read(e).catch(()=>{})!==void 0}async setPriority(e,n){let s=this.get(e);if(s)return s.setPriority(n),!0;if(!await this.hasRecord(e))return!1;let r=n===void 0||n<=0?void 0:Math.floor(n);return await this.persistPriority(e,r),!0}async persistPriority(e,n){await this.enqueueMetaWrite(e,async()=>{let s=await this.store.read(e);if(!s)return;let r={...s,updatedAt:new Date().toISOString()};n===void 0?delete r.priority:r.priority=n,await this.store.write(r)}),this.invalidateListCache()}async setTitle(e,n){let s=this.get(e);return s?(await s.retitle(n),!0):await this.hasRecord(e)?(await this.persistTitle(e,n),!0):!1}async persistTitle(e,n){await this.enqueueMetaWrite(e,async()=>{let s=await this.store.read(e);s&&await this.store.write({...s,title:n,updatedAt:new Date().toISOString()})})}async persistSynopsis(e,n,s){await this.enqueueMetaWrite(e,async()=>{let r=await this.store.read(e);r&&await this.store.write({...r,synopsis:n,summarizedThroughEntry:s,updatedAt:new Date().toISOString()})})}async persistAgentChange(e,n,s){await this.enqueueMetaWrite(e,async()=>{let r=await this.store.read(e);r&&await this.store.write({...r,agentId:n,upstreamSessionId:s,updatedAt:new Date().toISOString()})})}async persistSnapshot(e,n){await this.enqueueMetaWrite(e,async()=>{let s=await this.store.read(e);s&&await this.store.write({...s,...n.currentModel!==void 0?{currentModel:n.currentModel}:{},...n.currentMode!==void 0?{currentMode:n.currentMode}:{},...n.currentUsage!==void 0?{currentUsage:n.currentUsage}:{},...n.agentCommands!==void 0?{agentCommands:n.agentCommands}:{},...n.agentModes!==void 0?{agentModes:n.agentModes}:{},...n.agentModels!==void 0?{agentModels:n.agentModels}:{},...n.interactive!==void 0?{interactive:n.interactive}:{},...n.cwd!==void 0?{cwd:n.cwd}:{},updatedAt:new Date().toISOString()})})}enqueueMetaWrite(e,n){let r=(this.metaWriteQueues.get(e)??Promise.resolve()).then(n,n),i=r.catch(()=>{});return this.metaWriteQueues.set(e,i),i.finally(()=>{this.metaWriteQueues.get(e)===i&&this.metaWriteQueues.delete(e)}),r}async closeAll(){let e=[...this.sessions.values()];await Promise.allSettled(e.map(n=>n.close({deleteRecord:!1}))),this.sessions.clear()}async flushSynopsis(e){await this.synopsisCoordinator.flush(e)}async shutdownSynopsis(){await this.synopsisCoordinator.shutdown()}scheduleSynopsis(e){this.synopsisCoordinator.schedule(e)}async flushMetaWrites(){let e=[...this.metaWriteQueues.values()];e.length!==0&&await Promise.allSettled(e)}async flushHistoryWrites(){await this.histories.flushAll()}async resurrectPendingQueues(){let e=await this.store.list().catch(()=>[]);for(let n of e){let s=await fu(n.sessionId).catch(()=>[]);if(s.length===0)continue;let r=Date.now(),i=s.filter(d=>r-d.enqueuedAt<Uu),o=s.length-i.length;if(o>0&&(this.logger?.info(`queue replay: dropping ${o} stale prompt(s) for ${n.sessionId} (TTL ${Uu/1e3}s)`),await Dr(n.sessionId,i).catch(()=>{})),i.length===0)continue;let a=await this.loadFromDisk(n.sessionId).catch(()=>{});if(!a){this.logger?.warn(`queue replay: no meta for ${n.sessionId}; discarding ${i.length} entr${i.length===1?"y":"ies"}`),await Dr(n.sessionId,[]).catch(()=>{});continue}try{let d=await this.resurrect(a);this.logger?.info(`queue replay: resurrected ${n.sessionId} and replaying ${i.length} prompt(s)`),d.replayPersistedQueue(i)}catch(d){this.logger?.warn(`queue replay: failed to resurrect ${n.sessionId}: ${d.message}`)}}}};function hw(t,e){if(typeof t!="string"||t.length===0)return!1;let n=Vr.resolve(t),s=Vr.resolve(e);return n===s||n.startsWith(s+Vr.sep)}function gw(t,e){let s=(t.mergedAvailableCommands().length>0?t.agentOnlyAdvertisedCommands().map(l=>l.description!==void 0?{name:l.name,description:l.description}:{name:l.name}):void 0)??e?.agentCommands,r=t.availableModes(),o=(r.length>0?r.map(l=>{let f={id:l.id};return l.name!==void 0&&(f.name=l.name),l.description!==void 0&&(f.description=l.description),f}):void 0)??e?.agentModes,a=t.availableModels(),c=(a.length>0?a.map(l=>{let f={modelId:l.modelId};return l.name!==void 0&&(f.name=l.name),l.description!==void 0&&(f.description=l.description),f}):void 0)??e?.agentModels;return id({sessionId:t.sessionId,lineageId:e?.lineageId??Ur(),upstreamSessionId:t.upstreamSessionId,importedFromSessionId:e?.importedFromSessionId,importedFromUpstreamSessionId:e?.importedFromUpstreamSessionId,importedFromMachine:e?.importedFromMachine,agentId:t.agentId,cwd:t.cwd,title:t.title,synopsis:e?.synopsis,summarizedThroughEntry:e?.summarizedThroughEntry,agentArgs:t.agentArgs,currentModel:t.currentModel??e?.currentModel,currentMode:t.currentMode??e?.currentMode,currentUsage:Qu(t.currentUsage)??e?.currentUsage,agentCommands:s,agentModes:o,agentModels:c,parentSessionId:t.parentSessionId??e?.parentSessionId,forkedFromSessionId:t.forkedFromSessionId??e?.forkedFromSessionId,forkedFromMessageId:t.forkedFromMessageId??e?.forkedFromMessageId,originatingClient:t.originatingClient??e?.originatingClient,interactive:t.interactive??e?.interactive,priority:t.priority??e?.priority,createdAt:e?.createdAt??new Date(t.createdAt).toISOString()})}function Qu(t){if(!t)return;let e={};return t.used!==void 0&&(e.used=t.used),t.size!==void 0&&(e.size=t.size),t.costAmount!==void 0&&(e.costAmount=t.costAmount),t.costCurrency!==void 0&&(e.costCurrency=t.costCurrency),t.cumulativeCost!==void 0&&(e.cumulativeCost=t.cumulativeCost),Object.keys(e).length>0?e:void 0}function yw(t){return t?{...t}:void 0}function ww(t,e){if(e&&t==="claude-acp")return{claudeCode:{options:{model:e}}}}function ju(t){let e=Ue(t.currentModelId)??Ue(t.currentModel)??Ue(t.modelId)??Ue(t.model);if(e)return e;let n=t.models;if(n&&typeof n=="object"&&!Array.isArray(n)){let i=Ue(n.currentModelId)??Ue(n.currentModel);if(i)return i}let s=t._meta;if(s&&typeof s=="object"&&!Array.isArray(s)){for(let[i,o]of Object.entries(s))if(i!=="hydra-acp"&&o&&typeof o=="object"&&!Array.isArray(o)){let a=Ue(o.modelId)??Ue(o.model)??Ue(o.currentModelId);if(a)return a}}let r=fo(t,"model");if(r){let i=Ue(r.currentValue);if(i)return i}}function Ue(t){if(typeof t!="string")return;let e=t.trim();return e.length>0?e:void 0}function fo(t,e){let n=t.configOptions;if(Array.isArray(n))for(let s of n){if(!s||typeof s!="object"||Array.isArray(s))continue;let r=s;if(r.id===e)return r}}function qu(t){return t.length>0?t:void 0}function Wu(t){let e=as(t.availableModels);if(e.length>0)return e;let n=t.models;if(n&&typeof n=="object"&&!Array.isArray(n)){let i=as(n.availableModels);if(i.length>0)return i}let s=t._meta;if(s&&typeof s=="object"&&!Array.isArray(s)){for(let[i,o]of Object.entries(s))if(i!=="hydra-acp"&&o&&typeof o=="object"&&!Array.isArray(o)){let a=as(o.availableModels);if(a.length>0)return a}}let r=fo(t,"model");if(r){let i=as(r.options);if(i.length>0)return i}return[]}function zu(t){let e=Qs(t.availableModes);if(e.length>0)return e;let n=t.modes;if(n&&typeof n=="object"&&!Array.isArray(n)){let i=Qs(n.availableModes);if(i.length>0)return i}let s=t._meta;if(s&&typeof s=="object"&&!Array.isArray(s)){for(let[i,o]of Object.entries(s))if(i!=="hydra-acp"&&o&&typeof o=="object"&&!Array.isArray(o)){let a=Qs(o.availableModes);if(a.length>0)return a}}let r=fo(t,"mode");if(r){let i=Qs(r.options);if(i.length>0)return i}return[]}function Ju(t){let e=Ue(t.currentModeId)??Ue(t.currentMode)??Ue(t.modeId)??Ue(t.mode);if(e)return e;let n=t.modes;if(n&&typeof n=="object"&&!Array.isArray(n)){let i=Ue(n.currentModeId)??Ue(n.currentMode);if(i)return i}let s=t._meta;if(s&&typeof s=="object"&&!Array.isArray(s)){for(let[i,o]of Object.entries(s))if(i!=="hydra-acp"&&o&&typeof o=="object"&&!Array.isArray(o)){let a=Ue(o.currentModeId)??Ue(o.currentMode)??Ue(o.modeId);if(a)return a}}let r=fo(t,"mode");if(r){let i=Ue(r.currentValue);if(i)return i}}async function Ku(t){let{agent:e,upstreamSessionId:n,persistedMode:s,agentReportedMode:r,advertisedModes:i,logger:o}=t;if(!s)return r;if(s===r)return s;if(i&&i.length>0&&!i.some(a=>a.id===s)){let a=i.map(d=>d.id).join(", ");return o?.warn(`resurrect: persisted currentMode=${JSON.stringify(s)} not in agent's availableModes ([${a}]); skipping session/set_mode, session will use ${JSON.stringify(r)}`),r}try{return o?.info(`resurrect: pushing persisted modeId=${JSON.stringify(s)} to agent (agentReported=${JSON.stringify(r)})`),await e.connection.request("session/set_mode",{sessionId:n,modeId:s}),o?.info(`resurrect: session/set_mode accepted, effectiveMode=${JSON.stringify(s)}`),s}catch(a){return o?.warn(`resurrect: session/set_mode rejected by agent for modeId=${JSON.stringify(s)} (${a.message}); session will use ${JSON.stringify(r)}`),r}}async function Vu(t){let{agent:e,upstreamSessionId:n,persistedModel:s,agentReportedModel:r,logger:i}=t;if(!s)return r;if(s===r)return s;try{return i?.info(`resurrect: pushing persisted modelId=${JSON.stringify(s)} to agent (agentReported=${JSON.stringify(r)})`),await e.connection.request("session/set_model",{sessionId:n,modelId:s}),i?.info(`resurrect: session/set_model accepted, effectiveModel=${JSON.stringify(s)}`),s}catch(o){return i?.warn(`resurrect: session/set_model rejected by agent for modelId=${JSON.stringify(s)} (${o.message}); session will use ${JSON.stringify(r)}`),r}}function bw(t){for(let e=t.length-1;e>=0;e--){let n=t[e];if(!n||n.method!=="session/update")continue;let s=n.params?.update;if(s?.sessionUpdate==="turn_complete"&&!(typeof s.messageId!="string"||s.messageId.length===0))return{index:e,messageId:s.messageId}}}async function Yu(t){try{let e=await us.readFile(P.tuiHistoryFile(t),"utf8"),n=[];for(let s of e.split(`
|
|
236
|
-
`))if(s.length!==0)try{let r=JSON.parse(s);typeof r=="string"&&n.push(r)}catch{}return n}catch{return[]}}async function yd(t){try{let e=await
|
|
254
|
+
`)){if(f.length===0)continue;let u;try{u=JSON.parse(f)}catch{continue}if(!u||typeof u!="object"||Array.isArray(u))continue;let p=u;typeof p.method=="string"&&typeof p.recordedAt=="number"&&o.push({method:p.method,params:p.params,recordedAt:p.recordedAt})}let a=o.length>this.maxEntries?o.slice(-this.maxEntries):o;if(!s)return a;let d=new Map,c=async f=>{let u=d.get(f);if(u!==void 0)return u;let p=await Ui(e,f);return d.set(f,p),p},l=[];for(let f of a)l.push(await Du(f,c));return l}async flushAll(){let e=[...this.writeQueues.values()];e.length!==0&&await Promise.allSettled(e)}async delete(e){if(qr.test(e))return this.enqueue(e,async()=>{try{await it.unlink(P.historyFile(e))}catch(n){if(n.code!=="ENOENT")throw n}await _l(e);try{await it.rmdir(P.sessionDir(e))}catch(n){let s=n;if(s.code!=="ENOENT"&&s.code!=="ENOTEMPTY")throw n}})}enqueue(e,n){let r=(this.writeQueues.get(e)??Promise.resolve()).then(n,n),i=r.catch(()=>{});return this.writeQueues.set(e,i),i.finally(()=>{this.writeQueues.get(e)===i&&this.writeQueues.delete(e)}),r}};ue();Ne();oo();us();Xi();dt();Lt();Va();var ju=900*1e3,hw="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",ao=mw(hw,16),lo=class t{constructor(e,n,s,r={}){this.registry=e;this.spawner=n??(i=>_n.spawn(i)),this.store=s??new eo,this.tombstones=r.tombstones??new to,this.sessionHistoryMaxEntries=r.sessionHistoryMaxEntries??1e3,this.histories=new ro({maxEntries:this.sessionHistoryMaxEntries}),this.idleTimeoutMs=r.idleTimeoutMs??0,this.idleEventTimeoutMs=r.idleEventTimeoutMs??3e4,this.defaultModels=r.defaultModels??{},this.synopsisAgent=r.synopsisAgent,this.synopsisModel=r.synopsisModel,this.synopsisOnClose=r.synopsisOnClose??!1,this.defaultTransformers=r.defaultTransformers??[],this.logger=r.logger,this.npmRegistry=r.npmRegistry,this.extensionCommands=r.extensionCommands,this.defaultCwd=r.defaultCwd??"~",this.synopsisCoordinator=new so({registry:this.registry,store:this.store,histories:this.histories,synopsisAgent:this.synopsisAgent,synopsisModel:this.synopsisModel,persistTitle:async(i,o)=>{let a=this.get(i);if(a){await a.retitle(o);return}await this.persistTitle(i,o)},persistSynopsis:(i,o,a)=>this.persistSynopsis(i,o,a),logger:this.logger,npmRegistry:this.npmRegistry}),this.refreshAgentCatalog()}registry;sessions=new Map;resurrectionInflight=new Map;spawner;store;tombstones;histories;idleTimeoutMs;defaultModels;synopsisAgent;synopsisModel;synopsisOnClose;defaultTransformers;idleEventTimeoutMs;sessionHistoryMaxEntries;metaWriteQueues=new Map;listCache=new Map;static LIST_CACHE_TTL_MS=500;logger;npmRegistry;extensionCommands;defaultCwd;synopsisCoordinator;agentCatalog=[];async refreshAgentCatalog(){try{let{agents:e}=await zs(this.registry);this.agentCatalog=e.map(n=>({id:n.id,name:n.name,...n.description!==void 0?{description:n.description}:{}}))}catch{}}async create(e){let n=await this.bootstrapAgent({agentId:e.agentId,cwd:e.cwd,agentArgs:e.agentArgs,mcpServers:e.mcpServers,model:e.model,onInstallProgress:e.onInstallProgress});if(e.transformChain&&e.transformChain.length>0){let r={...n.agentCapabilities??{}};for(let i of e.transformChain)if(i.intercepts.has("agent:initialize"))try{let o=await i.connection.request("hydra-acp/transformer/message",{token:`t_${ao()}`,phase:"response",method:"initialize",direction:"agent\u2192daemon",sessionId:"(pre-session)",envelope:r});o.action==="stop"&&o.payload&&(r=o.payload)}catch{}n.agentCapabilities=r}let s=new Qs({cwd:e.cwd,agentId:e.agentId,agent:n.agent,upstreamSessionId:n.upstreamSessionId,agentMeta:n.agentMeta,agentCapabilities:n.agentCapabilities,title:e.title,agentArgs:e.agentArgs,idleTimeoutMs:this.idleTimeoutMs,idleEventTimeoutMs:this.idleEventTimeoutMs,logger:this.logger,spawnReplacementAgent:r=>this.bootstrapAgent({...r,mcpServers:[]}),listSessions:()=>this.list(),availableAgents:()=>this.agentCatalog,historyStore:this.histories,historyMaxEntries:this.sessionHistoryMaxEntries,currentModel:n.initialModel,currentMode:n.initialMode,agentModes:n.initialModes,agentModels:n.initialModels,transformChain:e.transformChain,parentSessionId:e.parentSessionId,originatingClient:e.originatingClient,interactive:e.interactive,extensionCommands:this.extensionCommands,scheduleSynopsis:()=>this.synopsisCoordinator.schedule(s.sessionId)});return await this.attachManagerHooks(s),s}async resurrect(e){let n=this.sessions.get(e.hydraSessionId);if(n){if(n.upstreamSessionId!==e.upstreamSessionId){let i=new Error(`session ${e.hydraSessionId} already exists with a different upstream id`);throw i.code=B.AlreadyAttached,i}return n}let s=this.resurrectionInflight.get(e.hydraSessionId);if(s)return s;let r=this.doResurrect(e);this.resurrectionInflight.set(e.hydraSessionId,r);try{return await r}finally{this.resurrectionInflight.delete(e.hydraSessionId)}}async doResurrect(e){let n=this.sessions.get(e.hydraSessionId);if(n)return n;let s=await this.registry.getAgent(e.agentId);if(!s){let h=new Error(`agent ${e.agentId} not found in registry; cannot resurrect`);throw h.code=B.AgentNotInstalled,h}if(e.upstreamSessionId==="")return this.doResurrectFromImport(e);if(!await this.dirExists(e.cwd))return this.doResurrectFromImport(e);let r=await $n(s,e.agentArgs??[],{npmRegistry:this.npmRegistry,onInstallProgress:e.onInstallProgress}),i=this.spawner({agentId:e.agentId,cwd:e.cwd,plan:r}),o;try{o=(await i.connection.request("initialize",{protocolVersion:yt,clientCapabilities:{},clientInfo:{name:"hydra",version:me}})).agentCapabilities}catch(h){throw await i.kill().catch(()=>{}),h}let a;try{let h=bw(e.agentId,e.currentModel);a=await i.connection.request("session/load",{sessionId:e.upstreamSessionId,cwd:e.cwd,mcpServers:e.mcpServers??[],...h&&{_meta:h}})}catch(h){return process.stderr.write(`session/load failed for upstream ${e.upstreamSessionId} on ${e.agentId} (${h.message}); recovering via import-reseed
|
|
255
|
+
`),await i.kill().catch(()=>{}),this.doResurrectFromImport(e)}if(e.pendingHistorySync===!0)this.clearPendingHistorySync(e.hydraSessionId).catch(()=>{});else{let h=i.connection.drainBuffered("session/update");this.logger?.info(`resurrect: drain1 dropped ${h} buffered session/update(s) for sessionId=${e.hydraSessionId}`)}let d=Ku(a??{}),c=e.agentModes??Wu(Ju(a??{}));this.logger?.info(`resurrect: sessionId=${e.hydraSessionId} persistedMode=${JSON.stringify(e.currentMode)} agentReportedMode=${JSON.stringify(d)} advertisedModes=${JSON.stringify(c?.map(h=>h.id))}`);let l=await Vu({agent:i,upstreamSessionId:e.upstreamSessionId,persistedMode:e.currentMode,agentReportedMode:d,advertisedModes:c,logger:this.logger});this.logger?.info(`resurrect: effectiveMode=${JSON.stringify(l)} for sessionId=${e.hydraSessionId}`);let f=qu(a??{}),u=Wu(zu(a??{}))??e.agentModels;if(this.logger?.info(`resurrect: sessionId=${e.hydraSessionId} persistedModel=${JSON.stringify(e.currentModel)} agentReportedModel=${JSON.stringify(f)} advertisedModels=${JSON.stringify(u?.map(h=>h.modelId))}`),e.pendingHistorySync!==!0){let h=i.connection.drainBuffered("session/update");this.logger?.info(`resurrect: drain2 (post-mode-restore) dropped ${h} buffered session/update(s) for sessionId=${e.hydraSessionId}`)}let p=await Yu({agent:i,upstreamSessionId:e.upstreamSessionId,persistedModel:e.currentModel,agentReportedModel:f,logger:this.logger});if(e.pendingHistorySync!==!0){let h=i.connection.drainBuffered("session/update");this.logger?.info(`resurrect: drain3 (post-model-restore) dropped ${h} buffered session/update(s) for sessionId=${e.hydraSessionId}`)}let g=new Qs({sessionId:e.hydraSessionId,cwd:e.cwd,agentId:e.agentId,agent:i,upstreamSessionId:e.upstreamSessionId,agentMeta:a?._meta,agentCapabilities:o,title:e.title,agentArgs:e.agentArgs,idleTimeoutMs:this.idleTimeoutMs,logger:this.logger,spawnReplacementAgent:h=>this.bootstrapAgent({...h,mcpServers:e.mcpServers??[]}),listSessions:()=>this.list(),availableAgents:()=>this.agentCatalog,historyStore:this.histories,historyMaxEntries:this.sessionHistoryMaxEntries,currentModel:p,currentMode:l,currentUsage:e.currentUsage,agentCommands:e.agentCommands,agentModes:c,agentModels:u,firstPromptSeeded:!!e.title,createdAt:e.createdAt?new Date(e.createdAt).getTime():void 0,originatingClient:e.originatingClient,interactive:e.interactive,priority:e.priority,forkedFromSessionId:e.forkedFromSessionId,forkedFromMessageId:e.forkedFromMessageId,extensionCommands:this.extensionCommands,scheduleSynopsis:()=>this.synopsisCoordinator.schedule(g.sessionId)});return await this.attachManagerHooks(g),g}async doResurrectFromImport(e){let n=await this.resolveResurrectCwd(e.cwd),s=await this.bootstrapAgent({agentId:e.agentId,cwd:n,agentArgs:e.agentArgs,mcpServers:e.mcpServers??[],onInstallProgress:e.onInstallProgress,model:e.currentModel}),r=e.agentModes??s.initialModes,i=await Vu({agent:s.agent,upstreamSessionId:s.upstreamSessionId,persistedMode:e.currentMode,agentReportedMode:s.initialMode,advertisedModes:r,logger:this.logger}),o=e.agentModels??s.initialModels,a=await Yu({agent:s.agent,upstreamSessionId:s.upstreamSessionId,persistedModel:e.currentModel,agentReportedModel:s.initialModel,logger:this.logger});s.agent.connection.drainBuffered("session/update");let d=new Qs({sessionId:e.hydraSessionId,cwd:n,agentId:e.agentId,agent:s.agent,upstreamSessionId:s.upstreamSessionId,agentMeta:s.agentMeta,agentCapabilities:s.agentCapabilities,title:e.title,agentArgs:e.agentArgs,idleTimeoutMs:this.idleTimeoutMs,logger:this.logger,spawnReplacementAgent:c=>this.bootstrapAgent({...c,mcpServers:e.mcpServers??[]}),listSessions:()=>this.list(),availableAgents:()=>this.agentCatalog,historyStore:this.histories,historyMaxEntries:this.sessionHistoryMaxEntries,currentModel:a,currentMode:i,currentUsage:e.currentUsage,agentCommands:e.agentCommands,agentModes:r,agentModels:o,firstPromptSeeded:!!e.title,createdAt:e.createdAt?new Date(e.createdAt).getTime():void 0,originatingClient:e.originatingClient,interactive:e.interactive,priority:e.priority,forkedFromSessionId:e.forkedFromSessionId,forkedFromMessageId:e.forkedFromMessageId,extensionCommands:this.extensionCommands,scheduleSynopsis:()=>this.synopsisCoordinator.schedule(d.sessionId)});return await this.attachManagerHooks(d),d.seedFromImport().catch(()=>{}),d}async dirExists(e){try{return(await fs.stat(e)).isDirectory()}catch{return!1}}async reapIfOrphanedNonInteractive(e){let n=this.sessions.get(e);!n||n.attachedCount>0||n.interactive!==!0&&(this.logger?.info(`reaping orphaned non-interactive session ${e} (agent killed, cold record kept)`),await n.close({deleteRecord:!1}).catch(()=>{}))}async resolveResurrectCwd(e){return await this.dirExists(e)?e:Ft(this.defaultCwd)}async syncFromAgent(e){let n=await this.registry.getAgent(e);if(!n){let p=new Error(`agent ${e} not found in registry`);throw p.code=B.AgentNotInstalled,p}let s=await $n(n,[],{npmRegistry:this.npmRegistry}),r=this.spawner({agentId:e,cwd:uo.homedir(),plan:s}),i;try{i=await r.connection.request("initialize",{protocolVersion:yt,clientCapabilities:{},clientInfo:{name:"hydra",version:me}})}catch(p){throw await r.kill().catch(()=>{}),p}if((i.agentCapabilities??{}).sessionCapabilities?.list===void 0)throw await r.kill().catch(()=>{}),new Error(`agent ${e} does not advertise sessionCapabilities.list; cannot sync`);let a;try{a=await this.collectAgentSessions(r)}catch(p){throw await r.kill().catch(()=>{}),p}await r.kill().catch(()=>{});let d=new Set;for(let p of this.sessions.values())d.add(`${p.agentId}::${p.upstreamSessionId}`);let c=await this.store.list().catch(()=>[]);for(let p of c)d.add(`${p.agentId}::${p.upstreamSessionId}`);let l=P.sessionsDir(),f=[],u=0;for(let p of a){let g=`${e}::${p.sessionId}`;if(d.has(g)){u+=1;continue}if(gw(p.cwd,l)){u+=1;continue}let h=await this.tombstones.read(e,p.sessionId).catch(()=>{});if(h){if(!Su(h,p.updatedAt)){u+=1;continue}await this.tombstones.remove(e,p.sessionId).catch(()=>{}),this.logger?.info(`syncFromAgent: resurrecting tombstoned ${e}/${p.sessionId} (upstream updatedAt advanced past ${h.upstreamUpdatedAt??"<unset>"})`)}d.add(g);let w=`${an}${ao()}`,v=new Date().toISOString(),b=p.updatedAt??v,x={sessionId:w,lineageId:Ur(),upstreamSessionId:p.sessionId,agentId:e,cwd:p.cwd,pendingHistorySync:!0,interactive:!0,createdAt:b,updatedAt:b};p.title!==void 0&&(x.title=p.title);let C=id(x);await this.store.write(C),f.push({version:1,...C})}return{synced:f,skipped:u}}async collectAgentSessions(e){let n=[],s;for(let r=0;r<100;r+=1){let i={};s!==void 0&&(i.cursor=s);let o=await e.connection.request("session/list",i),a=Array.isArray(o.sessions)?o.sessions:[];for(let d of a){if(typeof d.sessionId!="string"||typeof d.cwd!="string")continue;let c={sessionId:d.sessionId,cwd:d.cwd};typeof d.title=="string"&&(c.title=d.title),typeof d.updatedAt=="string"&&(c.updatedAt=d.updatedAt),n.push(c)}if(typeof o.nextCursor!="string"||o.nextCursor.length===0)break;s=o.nextCursor}return n}async applySeedModel(e,n,s,r){try{return await e.connection.request("session/set_model",{sessionId:n,modelId:s}),this.logger?.info(`${r}: session/set_model accepted`),!0}catch(i){return this.logger?.warn(`${r} rejected by agent (${i.message}); session will use the agent's own default`),!1}}async bootstrapAgent(e){let n=await this.registry.getAgent(e.agentId);if(!n){let i=new Error(`agent ${e.agentId} not found in registry`);throw i.code=B.AgentNotInstalled,i}let s=await $n(n,e.agentArgs??[],{npmRegistry:this.npmRegistry,onInstallProgress:e.onInstallProgress}),r=this.spawner({agentId:e.agentId,cwd:e.cwd,plan:s});try{let o=(await r.connection.request("initialize",{protocolVersion:yt,clientCapabilities:{},clientInfo:{name:"hydra",version:me}})).agentCapabilities,a=await r.connection.request("session/new",{cwd:e.cwd,mcpServers:e.mcpServers??[]}),d=a.sessionId;if(typeof d!="string")throw new Error(`agent ${e.agentId} returned a non-string sessionId from session/new`);let c=qu(a),l=zu(a),f=e.model??this.defaultModels[e.agentId];if(f&&f!==c){let g=Ks(f,l),h=e.model!==void 0?`model=${JSON.stringify(f)}`:`defaultModels[${e.agentId}]=${JSON.stringify(f)}`;if(g.kind==="exact"||g.kind==="none")await this.applySeedModel(r,d,f,h)&&(c=f);else if(g.kind==="resolved")(g.modelId===c||await this.applySeedModel(r,d,g.modelId,`${h} resolved to ${JSON.stringify(g.modelId)}`))&&(c=g.modelId);else if(g.kind==="ambiguous")this.logger?.warn(`${h} is ambiguous (trailing-segment matches [${g.candidates.join(", ")}]); skipping session/set_model, session will use ${JSON.stringify(c)}`);else{let w=l.map(v=>v.modelId).join(", ");this.logger?.warn(`${h} not in agent's availableModels ([${w}]); skipping session/set_model, session will use ${JSON.stringify(c)}`)}}let u=Ju(a),p=Ku(a);return{agent:r,upstreamSessionId:d,agentMeta:a._meta,agentCapabilities:o,initialModel:c,initialModels:l.length>0?l:void 0,initialModes:u.length>0?u:void 0,initialMode:p}}catch(i){throw await r.kill().catch(()=>{}),i}}async attachManagerHooks(e){e.onClose(({deleteRecord:n})=>{if(this.sessions.delete(e.sessionId),this.invalidateListCache(),n){if(e.upstreamSessionId){let s=co({interactive:e.interactive,...e.originatingClient?{originatingClient:e.originatingClient}:{}},!0);this.tombstones.add({agentId:e.agentId,upstreamSessionId:e.upstreamSessionId,deletedAt:new Date().toISOString(),upstreamUpdatedAt:new Date(e.updatedAt).toISOString(),cwd:e.cwd,title:e.title,reason:"user",...s!==void 0?{interactive:s}:{}}).catch(()=>{})}this.store.delete(e.sessionId).catch(()=>{}),this.histories.delete(e.sessionId).catch(()=>{});return}e.firstPromptSeeded&&this.synopsisOnClose&&this.synopsisCoordinator.schedule(e.sessionId)}),e.onTitleChange(n=>{this.persistTitle(e.sessionId,n).catch(()=>{})}),e.onPriorityChange(n=>{this.persistPriority(e.sessionId,n).catch(()=>{})}),e.onAgentChange(({agentId:n,upstreamSessionId:s})=>{this.persistAgentChange(e.sessionId,n,s).catch(()=>{})}),e.onModelChange(n=>{this.persistSnapshot(e.sessionId,{currentModel:n}).catch(()=>{})}),e.onModeChange(n=>{this.persistSnapshot(e.sessionId,{currentMode:n}).catch(()=>{})}),e.onInteractiveChange(n=>{this.persistSnapshot(e.sessionId,{interactive:n}).catch(()=>{})}),e.onUsageChange(n=>{this.persistSnapshot(e.sessionId,{currentUsage:Gu(n)}).catch(()=>{})}),e.onAgentCommandsChange(n=>{this.persistSnapshot(e.sessionId,{agentCommands:n.map(s=>({name:s.name,...s.description!==void 0?{description:s.description}:{}}))}).catch(()=>{})}),e.onAgentModesChange(n=>{this.persistSnapshot(e.sessionId,{agentModes:n.map(s=>({id:s.id,...s.name!==void 0?{name:s.name}:{},...s.description!==void 0?{description:s.description}:{}}))}).catch(()=>{})}),e.onAgentModelsChange(n=>{this.persistSnapshot(e.sessionId,{agentModels:n.map(s=>({modelId:s.modelId,...s.name!==void 0?{name:s.name}:{},...s.description!==void 0?{description:s.description}:{}}))}).catch(()=>{})}),this.sessions.set(e.sessionId,e),this.invalidateListCache(),await this.enqueueMetaWrite(e.sessionId,async()=>{let n=await this.store.read(e.sessionId),s=yw(e,n);await this.store.write(s)}).catch(()=>{})}async getHistory(e){if(this.sessions.has(e))return this.histories.load(e).catch(()=>[]);if(await this.store.read(e))return this.histories.load(e).catch(()=>[])}async loadHistory(e){return this.histories.load(e)}async loadToolBlob(e,n){return Ui(e,n)}async loadFromDisk(e){let n=await this.store.read(e);if(!n)return;let s=n.title;return s||(s=await this.deriveTitleFromHistory(e)),{hydraSessionId:n.sessionId,upstreamSessionId:n.upstreamSessionId,agentId:n.agentId,cwd:n.cwd,title:s,synopsis:n.synopsis,summarizedThroughEntry:n.summarizedThroughEntry,agentArgs:n.agentArgs,currentModel:n.currentModel,currentMode:n.currentMode,currentUsage:ww(n.currentUsage?{...n.currentUsage,cumulativeCost:(n.currentUsage.cumulativeCost??0)+(n.currentUsage.costAmount??0),costAmount:void 0}:void 0),agentCommands:n.agentCommands,agentModes:n.agentModes,agentModels:n.agentModels,createdAt:n.createdAt,pendingHistorySync:n.pendingHistorySync,originatingClient:n.originatingClient,interactive:n.interactive,priority:n.priority,forkedFromSessionId:n.forkedFromSessionId,forkedFromMessageId:n.forkedFromMessageId}}async clearPendingHistorySync(e){await this.enqueueMetaWrite(e,async()=>{let n=await this.store.read(e);if(!n||n.pendingHistorySync!==!0)return;let s={...n};delete s.pendingHistorySync,await this.store.write(s)})}async deriveTitleFromHistory(e){let n=await this.histories.load(e).catch(()=>[]);for(let s of n){let r=s.params;if(r?.update?.sessionUpdate!=="prompt_received")continue;let i=Ys(r.update.prompt),o=Xa(i,200);if(o)return o}}get(e){return this.sessions.get(e)}liveSessions(){return this.sessions.values()}activeAgentVersions(){let e=new Map;for(let n of this.sessions.values()){let s=n.agent.agentId,r=n.agent.version,i=e.get(s);i||(i=new Set,e.set(s,i)),i.add(r)}return e}async resolveCanonicalId(e){if(this.sessions.has(e)||await this.store.read(e))return e;if(e.startsWith(an))return;let n=an+e;if(this.sessions.has(n)||await this.store.read(n))return n}require(e){let n=this.sessions.get(e);if(!n){let s=new Error(`session ${e} not found`);throw s.code=B.SessionNotFound,s}return n}liveListEntry(e){return{sessionId:e.sessionId,upstreamSessionId:e.upstreamSessionId,cwd:e.cwd,title:e.title,agentId:e.agentId,currentModel:e.currentModel,currentUsage:e.currentUsage,parentSessionId:e.parentSessionId,forkedFromSessionId:e.forkedFromSessionId,forkedFromMessageId:e.forkedFromMessageId,originatingClient:e.originatingClient,interactive:e.interactive,updatedAt:new Date(e.updatedAt).toISOString(),attachedClients:e.attachedCount,status:"live",busy:e.turnStartedAt!==void 0,awaitingInput:e.awaitingInput}}async list(e={}){let n=`${e.cwd??""}|${e.includeNonInteractive?"1":"0"}`,s=Date.now(),r=this.listCache.get(n);if(r&&r.expiresAt>s)return r.promise;let i=this.listUncached(e);return this.listCache.set(n,{expiresAt:s+t.LIST_CACHE_TTL_MS,promise:i}),i.catch(()=>{let o=this.listCache.get(n);o&&o.promise===i&&this.listCache.delete(n)}),i}invalidateListCache(){this.listCache.clear()}async listUncached(e={}){let n=[],s=new Set,r=o=>e.includeNonInteractive?!0:o===!0;for(let o of this.sessions.values()){if(e.cwd&&o.cwd!==e.cwd)continue;s.add(o.sessionId);let a=await yd(o.sessionId),d=co({interactive:o.interactive,...o.originatingClient?{originatingClient:o.originatingClient}:{}},a.hasContent);if(!r(d))continue;let c=a.mtime??new Date(o.updatedAt).toISOString();n.push({sessionId:o.sessionId,upstreamSessionId:o.upstreamSessionId,cwd:o.cwd,title:o.title,agentId:o.agentId,currentModel:o.currentModel,currentUsage:o.currentUsage,parentSessionId:o.parentSessionId,forkedFromSessionId:o.forkedFromSessionId,forkedFromMessageId:o.forkedFromMessageId,originatingClient:o.originatingClient,interactive:d,priority:o.priority,updatedAt:c,attachedClients:o.attachedCount,status:"live",busy:o.turnStartedAt!==void 0,awaitingInput:o.awaitingInput})}let i=await this.store.list().catch(()=>[]);for(let o of i){if(s.has(o.sessionId)||e.cwd&&o.cwd!==e.cwd)continue;let a=await yd(o.sessionId),d=co(o,a.hasContent);if(!r(d))continue;let c=a.mtime??o.updatedAt;n.push({sessionId:o.sessionId,upstreamSessionId:o.upstreamSessionId,cwd:o.cwd,title:o.title,agentId:o.agentId,currentModel:o.currentModel,currentUsage:o.currentUsage?{...o.currentUsage,costAmount:(o.currentUsage.cumulativeCost??0)+(o.currentUsage.costAmount??0)||void 0}:void 0,importedFromMachine:o.importedFromMachine,importedFromUpstreamSessionId:o.importedFromUpstreamSessionId,parentSessionId:o.parentSessionId,forkedFromSessionId:o.forkedFromSessionId,forkedFromMessageId:o.forkedFromMessageId,originatingClient:o.originatingClient,interactive:d,priority:o.priority,updatedAt:c,attachedClients:0,status:"cold",busy:!1,awaitingInput:!1})}return n.sort((o,a)=>o.updatedAt<a.updatedAt?1:-1),n}async exportBundle(e,n={}){let s=await this.store.read(e);if(!s)return;let r;if(s.lineageId)r=s;else{let c=Ur(),l={...s,lineageId:c};await this.enqueueMetaWrite(e,async()=>{let f=await this.store.read(e);f&&(f.lineageId||await this.store.write({...f,lineageId:c}))}).catch(()=>{}),r=l}let i=n.tools??"inline",o=await this.histories.load(e,i==="references"?{tools:"references"}:{}).catch(()=>[]),a=await Qu(e);if(i!=="references")return{record:r,history:o,promptHistory:a};let d={};for(let c of Bu(o)){let l=await Ml(e,c);l&&(d[c]=l.toString("base64"))}return{record:r,history:o,promptHistory:a,toolBlobs:d}}async importBundle(e,n={}){let s=await this.store.findByLineageId(e.session.lineageId);if(s){if(!n.replace){let o=new Error(`bundle already imported as ${s.sessionId}`);throw o.code=B.BundleAlreadyImported,o.existingSessionId=s.sessionId,o}let i=this.sessions.get(s.sessionId);return i&&await i.close({deleteRecord:!1}).catch(()=>{}),await this.writeImportedRecord({sessionId:s.sessionId,bundle:e,preservedCreatedAt:s.createdAt,cwd:n.cwd}),{sessionId:s.sessionId,importedFromSessionId:e.session.sessionId,replaced:!0}}let r=`${an}${ao()}`;return await this.writeImportedRecord({sessionId:r,bundle:e,cwd:n.cwd}),{sessionId:r,importedFromSessionId:e.session.sessionId,replaced:!1}}async forkSession(e,n={}){let s=await this.store.read(e);if(!s){let g=new Error(`source session not found: ${e}`);throw g.code=B.SessionNotFound,g}let r=n.agentId??s.agentId,i=r!==s.agentId;if(i&&!await this.registry.getAgent(r)){let h=new Error(`agent ${r} not found in registry`);throw h.code=B.AgentNotInstalled,h}let o=await this.histories.load(e).catch(()=>[]),a,d;if(n.forkAt!==void 0){if(a=Ga(o,n.forkAt),a<0){let g=new Error(`forkAt messageId not found in source history: ${n.forkAt}`);throw g.code=B.InvalidParams,g}d=n.forkAt}else{let g=vw(o);if(!g){let h=new Error(`source session ${e} has no completed turns to fork from`);throw h.code=B.InvalidParams,h}a=g.index,d=g.messageId}let c=o.slice(0,a+1),l=await Qu(e),f={...s,lineageId:Ur(),agentId:r,...i?{currentModel:void 0,currentMode:void 0,currentUsage:void 0,agentCommands:void 0,agentModes:void 0,agentModels:void 0}:{}},u=Kr({record:f,history:c,promptHistory:l.length>0?l:void 0,hydraVersion:me,machine:uo.hostname()}),p=`${an}${ao()}`;return await this.writeImportedRecord({sessionId:p,bundle:u,cwd:n.cwd,forkedFromSessionId:e,forkedFromMessageId:d}),{sessionId:p,forkedFromSessionId:e,forkedAt:d}}async writeImportedRecord(e){if(await this.histories.rewrite(e.sessionId,e.bundle.history),e.bundle.toolBlobs)for(let[i,o]of Object.entries(e.bundle.toolBlobs))await $l(e.sessionId,i,Buffer.from(o,"base64")).catch(()=>{});let n=new Date(e.bundle.session.updatedAt);Number.isNaN(n.getTime())||await fs.utimes(P.historyFile(e.sessionId),n,n).catch(()=>{}),e.bundle.promptHistory&&e.bundle.promptHistory.length>0&&await ls(P.tuiHistoryFile(e.sessionId),e.bundle.promptHistory).catch(()=>{});let s=new Date().toISOString(),r=e.forkedFromSessionId!==void 0;await this.enqueueMetaWrite(e.sessionId,async()=>{await this.store.write({sessionId:e.sessionId,lineageId:e.bundle.session.lineageId,upstreamSessionId:"",...r?{forkedFromSessionId:e.forkedFromSessionId,forkedFromMessageId:e.forkedFromMessageId}:{importedFromSessionId:e.bundle.session.sessionId,importedFromUpstreamSessionId:e.bundle.session.upstreamSessionId,importedFromMachine:e.bundle.exportedFrom.machine},agentId:e.bundle.session.agentId,cwd:e.cwd??e.bundle.session.cwd,title:e.bundle.session.title,synopsis:e.bundle.session.synopsis,summarizedThroughEntry:e.bundle.session.summarizedThroughEntry,currentModel:e.bundle.session.currentModel,currentMode:e.bundle.session.currentMode,currentUsage:e.bundle.session.currentUsage,agentCommands:e.bundle.session.agentCommands,agentModes:e.bundle.session.agentModes,interactive:e.bundle.session.interactive,originatingClient:e.bundle.session.originatingClient,priority:e.bundle.session.priority,createdAt:e.preservedCreatedAt??s,updatedAt:e.bundle.session.updatedAt})})}async deleteRecord(e){let n=await this.store.read(e);if(!n)return!1;if(n.upstreamSessionId){let s=await yd(e),r=co(n,s.hasContent);await this.tombstones.add({agentId:n.agentId,upstreamSessionId:n.upstreamSessionId,deletedAt:new Date().toISOString(),upstreamUpdatedAt:n.updatedAt,cwd:n.cwd,title:n.title,reason:"user",...r!==void 0?{interactive:r}:{}}).catch(()=>{})}return await this.store.delete(e).catch(()=>{}),await this.histories.delete(e).catch(()=>{}),this.invalidateListCache(),!0}async hasRecord(e){return await this.store.read(e).catch(()=>{})!==void 0}async setPriority(e,n){let s=this.get(e);if(s)return s.setPriority(n),!0;if(!await this.hasRecord(e))return!1;let r=n===void 0||n<=0?void 0:Math.floor(n);return await this.persistPriority(e,r),!0}async persistPriority(e,n){await this.enqueueMetaWrite(e,async()=>{let s=await this.store.read(e);if(!s)return;let r={...s,updatedAt:new Date().toISOString()};n===void 0?delete r.priority:r.priority=n,await this.store.write(r)}),this.invalidateListCache()}async setTitle(e,n){let s=this.get(e);return s?(await s.retitle(n),!0):await this.hasRecord(e)?(await this.persistTitle(e,n),!0):!1}async persistTitle(e,n){await this.enqueueMetaWrite(e,async()=>{let s=await this.store.read(e);s&&await this.store.write({...s,title:n,updatedAt:new Date().toISOString()})})}async persistSynopsis(e,n,s){await this.enqueueMetaWrite(e,async()=>{let r=await this.store.read(e);r&&await this.store.write({...r,synopsis:n,summarizedThroughEntry:s,updatedAt:new Date().toISOString()})})}async persistAgentChange(e,n,s){await this.enqueueMetaWrite(e,async()=>{let r=await this.store.read(e);r&&await this.store.write({...r,agentId:n,upstreamSessionId:s,updatedAt:new Date().toISOString()})})}async persistSnapshot(e,n){await this.enqueueMetaWrite(e,async()=>{let s=await this.store.read(e);s&&await this.store.write({...s,...n.currentModel!==void 0?{currentModel:n.currentModel}:{},...n.currentMode!==void 0?{currentMode:n.currentMode}:{},...n.currentUsage!==void 0?{currentUsage:n.currentUsage}:{},...n.agentCommands!==void 0?{agentCommands:n.agentCommands}:{},...n.agentModes!==void 0?{agentModes:n.agentModes}:{},...n.agentModels!==void 0?{agentModels:n.agentModels}:{},...n.interactive!==void 0?{interactive:n.interactive}:{},...n.cwd!==void 0?{cwd:n.cwd}:{},updatedAt:new Date().toISOString()})})}enqueueMetaWrite(e,n){let r=(this.metaWriteQueues.get(e)??Promise.resolve()).then(n,n),i=r.catch(()=>{});return this.metaWriteQueues.set(e,i),i.finally(()=>{this.metaWriteQueues.get(e)===i&&this.metaWriteQueues.delete(e)}),r}async closeAll(){let e=[...this.sessions.values()];await Promise.allSettled(e.map(n=>n.close({deleteRecord:!1}))),this.sessions.clear()}async flushSynopsis(e){await this.synopsisCoordinator.flush(e)}async shutdownSynopsis(){await this.synopsisCoordinator.shutdown()}scheduleSynopsis(e){this.synopsisCoordinator.schedule(e)}async flushMetaWrites(){let e=[...this.metaWriteQueues.values()];e.length!==0&&await Promise.allSettled(e)}async flushHistoryWrites(){await this.histories.flushAll()}async resurrectPendingQueues(){let e=await this.store.list().catch(()=>[]);for(let n of e){let s=await fu(n.sessionId).catch(()=>[]);if(s.length===0)continue;let r=Date.now(),i=s.filter(d=>r-d.enqueuedAt<ju),o=s.length-i.length;if(o>0&&(this.logger?.info(`queue replay: dropping ${o} stale prompt(s) for ${n.sessionId} (TTL ${ju/1e3}s)`),await Dr(n.sessionId,i).catch(()=>{})),i.length===0)continue;let a=await this.loadFromDisk(n.sessionId).catch(()=>{});if(!a){this.logger?.warn(`queue replay: no meta for ${n.sessionId}; discarding ${i.length} entr${i.length===1?"y":"ies"}`),await Dr(n.sessionId,[]).catch(()=>{});continue}try{let d=await this.resurrect(a);this.logger?.info(`queue replay: resurrected ${n.sessionId} and replaying ${i.length} prompt(s)`),d.replayPersistedQueue(i)}catch(d){this.logger?.warn(`queue replay: failed to resurrect ${n.sessionId}: ${d.message}`)}}}};function gw(t,e){if(typeof t!="string"||t.length===0)return!1;let n=Vr.resolve(t),s=Vr.resolve(e);return n===s||n.startsWith(s+Vr.sep)}function yw(t,e){let s=(t.mergedAvailableCommands().length>0?t.agentOnlyAdvertisedCommands().map(l=>l.description!==void 0?{name:l.name,description:l.description}:{name:l.name}):void 0)??e?.agentCommands,r=t.availableModes(),o=(r.length>0?r.map(l=>{let f={id:l.id};return l.name!==void 0&&(f.name=l.name),l.description!==void 0&&(f.description=l.description),f}):void 0)??e?.agentModes,a=t.availableModels(),c=(a.length>0?a.map(l=>{let f={modelId:l.modelId};return l.name!==void 0&&(f.name=l.name),l.description!==void 0&&(f.description=l.description),f}):void 0)??e?.agentModels;return id({sessionId:t.sessionId,lineageId:e?.lineageId??Ur(),upstreamSessionId:t.upstreamSessionId,importedFromSessionId:e?.importedFromSessionId,importedFromUpstreamSessionId:e?.importedFromUpstreamSessionId,importedFromMachine:e?.importedFromMachine,agentId:t.agentId,cwd:t.cwd,title:t.title,synopsis:e?.synopsis,summarizedThroughEntry:e?.summarizedThroughEntry,agentArgs:t.agentArgs,currentModel:t.currentModel??e?.currentModel,currentMode:t.currentMode??e?.currentMode,currentUsage:Gu(t.currentUsage)??e?.currentUsage,agentCommands:s,agentModes:o,agentModels:c,parentSessionId:t.parentSessionId??e?.parentSessionId,forkedFromSessionId:t.forkedFromSessionId??e?.forkedFromSessionId,forkedFromMessageId:t.forkedFromMessageId??e?.forkedFromMessageId,originatingClient:t.originatingClient??e?.originatingClient,interactive:t.interactive??e?.interactive,priority:t.priority??e?.priority,createdAt:e?.createdAt??new Date(t.createdAt).toISOString()})}function Gu(t){if(!t)return;let e={};return t.used!==void 0&&(e.used=t.used),t.size!==void 0&&(e.size=t.size),t.costAmount!==void 0&&(e.costAmount=t.costAmount),t.costCurrency!==void 0&&(e.costCurrency=t.costCurrency),t.cumulativeCost!==void 0&&(e.cumulativeCost=t.cumulativeCost),Object.keys(e).length>0?e:void 0}function ww(t){return t?{...t}:void 0}function bw(t,e){if(e&&t==="claude-acp")return{claudeCode:{options:{model:e}}}}function qu(t){let e=Ue(t.currentModelId)??Ue(t.currentModel)??Ue(t.modelId)??Ue(t.model);if(e)return e;let n=t.models;if(n&&typeof n=="object"&&!Array.isArray(n)){let i=Ue(n.currentModelId)??Ue(n.currentModel);if(i)return i}let s=t._meta;if(s&&typeof s=="object"&&!Array.isArray(s)){for(let[i,o]of Object.entries(s))if(i!=="hydra-acp"&&o&&typeof o=="object"&&!Array.isArray(o)){let a=Ue(o.modelId)??Ue(o.model)??Ue(o.currentModelId);if(a)return a}}let r=fo(t,"model");if(r){let i=Ue(r.currentValue);if(i)return i}}function Ue(t){if(typeof t!="string")return;let e=t.trim();return e.length>0?e:void 0}function fo(t,e){let n=t.configOptions;if(Array.isArray(n))for(let s of n){if(!s||typeof s!="object"||Array.isArray(s))continue;let r=s;if(r.id===e)return r}}function Wu(t){return t.length>0?t:void 0}function zu(t){let e=Fn(t.availableModels);if(e.length>0)return e;let n=t.models;if(n&&typeof n=="object"&&!Array.isArray(n)){let i=Fn(n.availableModels);if(i.length>0)return i}let s=t._meta;if(s&&typeof s=="object"&&!Array.isArray(s)){for(let[i,o]of Object.entries(s))if(i!=="hydra-acp"&&o&&typeof o=="object"&&!Array.isArray(o)){let a=Fn(o.availableModels);if(a.length>0)return a}}let r=fo(t,"model");if(r){let i=Fn(r.options);if(i.length>0)return i}return[]}function Ju(t){let e=ds(t.availableModes);if(e.length>0)return e;let n=t.modes;if(n&&typeof n=="object"&&!Array.isArray(n)){let i=ds(n.availableModes);if(i.length>0)return i}let s=t._meta;if(s&&typeof s=="object"&&!Array.isArray(s)){for(let[i,o]of Object.entries(s))if(i!=="hydra-acp"&&o&&typeof o=="object"&&!Array.isArray(o)){let a=ds(o.availableModes);if(a.length>0)return a}}let r=fo(t,"mode");if(r){let i=ds(r.options);if(i.length>0)return i}return[]}function Ku(t){let e=Ue(t.currentModeId)??Ue(t.currentMode)??Ue(t.modeId)??Ue(t.mode);if(e)return e;let n=t.modes;if(n&&typeof n=="object"&&!Array.isArray(n)){let i=Ue(n.currentModeId)??Ue(n.currentMode);if(i)return i}let s=t._meta;if(s&&typeof s=="object"&&!Array.isArray(s)){for(let[i,o]of Object.entries(s))if(i!=="hydra-acp"&&o&&typeof o=="object"&&!Array.isArray(o)){let a=Ue(o.currentModeId)??Ue(o.currentMode)??Ue(o.modeId);if(a)return a}}let r=fo(t,"mode");if(r){let i=Ue(r.currentValue);if(i)return i}}async function Vu(t){let{agent:e,upstreamSessionId:n,persistedMode:s,agentReportedMode:r,advertisedModes:i,logger:o}=t;if(!s)return r;if(s===r)return s;if(i&&i.length>0&&!i.some(a=>a.id===s)){let a=i.map(d=>d.id).join(", ");return o?.warn(`resurrect: persisted currentMode=${JSON.stringify(s)} not in agent's availableModes ([${a}]); skipping session/set_mode, session will use ${JSON.stringify(r)}`),r}try{return o?.info(`resurrect: pushing persisted modeId=${JSON.stringify(s)} to agent (agentReported=${JSON.stringify(r)})`),await e.connection.request("session/set_mode",{sessionId:n,modeId:s}),o?.info(`resurrect: session/set_mode accepted, effectiveMode=${JSON.stringify(s)}`),s}catch(a){return o?.warn(`resurrect: session/set_mode rejected by agent for modeId=${JSON.stringify(s)} (${a.message}); session will use ${JSON.stringify(r)}`),r}}async function Yu(t){let{agent:e,upstreamSessionId:n,persistedModel:s,agentReportedModel:r,logger:i}=t;if(!s)return r;if(s===r)return s;try{return i?.info(`resurrect: pushing persisted modelId=${JSON.stringify(s)} to agent (agentReported=${JSON.stringify(r)})`),await e.connection.request("session/set_model",{sessionId:n,modelId:s}),i?.info(`resurrect: session/set_model accepted, effectiveModel=${JSON.stringify(s)}`),s}catch(o){return i?.warn(`resurrect: session/set_model rejected by agent for modelId=${JSON.stringify(s)} (${o.message}); session will use ${JSON.stringify(r)}`),r}}function vw(t){for(let e=t.length-1;e>=0;e--){let n=t[e];if(!n||n.method!=="session/update")continue;let s=n.params?.update;if(s?.sessionUpdate==="turn_complete"&&!(typeof s.messageId!="string"||s.messageId.length===0))return{index:e,messageId:s.messageId}}}async function Qu(t){try{let e=await fs.readFile(P.tuiHistoryFile(t),"utf8"),n=[];for(let s of e.split(`
|
|
256
|
+
`))if(s.length!==0)try{let r=JSON.parse(s);typeof r=="string"&&n.push(r)}catch{}return n}catch{return[]}}async function yd(t){try{let e=await fs.stat(P.historyFile(t));return{mtime:new Date(e.mtimeMs).toISOString(),hasContent:e.size>0}}catch{return{hasContent:!1}}}function co(t,e){return t.interactive!==void 0?t.interactive:t.originatingClient?.name===cs?!1:e?!0:void 0}import{spawn as Iw}from"child_process";import*as Zs from"fs";import*as On from"fs/promises";import*as Xu from"path";var po=class{windowMs;maxFailures;now;recentExits=[];tripped_;constructor(e={}){this.windowMs=e.windowMs??3e5,this.maxFailures=e.maxFailuresInWindow??10,this.now=e.now??Date.now}recordExit(e,n,s){if(e===78){let o=`exited with code 78 (unrecoverable); fix and run \`${s}s start ${n}\``;return this.tripped_=o,{tripped:o}}let r=this.now();this.recentExits.push(r);let i=r-this.windowMs;for(;this.recentExits.length>0&&this.recentExits[0]<i;)this.recentExits.shift();if(this.recentExits.length>this.maxFailures){let o=Math.round(this.windowMs/6e4),a=`${this.recentExits.length} exits in ${o}m (crash loop); fix and run \`${s}s start ${n}\``;return this.tripped_=a,{tripped:a}}return"restart"}reset(){this.recentExits=[],this.tripped_=void 0}get tripped(){return this.tripped_}};var Sw=1e3,kw=6e4,wd=3e3,Xs=class{entries=new Map;stopping=!1;context;tokenRegistry;breakerOptions;restartBaseMs;restartCapMs;adapter;constructor(e,n,s,r={}){this.adapter=n,this.context=s,this.tokenRegistry=r.tokenRegistry,this.breakerOptions=r.breakerOptions,this.restartBaseMs=r.restartBaseMs??Sw,this.restartCapMs=r.restartCapMs??kw;for(let i of e)this.entries.set(i.name,this.makeEntry(i))}setContext(e){this.context=e}reportVersion(e,n){let s=this.entries.get(e);s&&(s.version=n)}async start(){if(!this.context)throw new Error(`${this.managerName()}: setContext must be called before start`);await On.mkdir(this.adapter.paths.dir(),{recursive:!0}),await this.reapOrphans();for(let e of this.entries.values())e.config.enabled&&this.spawn(e,0)}async stop(){this.stopping=!0;let e=[];for(let n of this.entries.values()){n.restartTimer&&(clearTimeout(n.restartTimer),n.restartTimer=void 0);let s=n.child;if(s){try{s.kill("SIGTERM")}catch{}e.push(new Promise(r=>{if(s.exitCode!==null||s.signalCode!==null){r();return}let i=setTimeout(()=>{try{s.kill("SIGKILL")}catch{}r()},wd);s.on("exit",()=>{clearTimeout(i),r()})}))}}await Promise.allSettled(e);for(let n of this.entries.values()){try{n.logStream?.end()}catch{}n.child=void 0,n.logStream=void 0,n.pid=void 0}}list(){return[...this.entries.values()].map(e=>this.infoFor(e))}get(e){let n=this.entries.get(e);return n?this.infoFor(n):void 0}has(e){return this.entries.has(e)}async startByName(e){let n=this.entries.get(e);if(!n)throw Yr(new Error(`unknown ${this.adapter.kind}: ${e}`),"NOT_FOUND");if(n.child)throw Yr(new Error(`${this.adapter.kind} ${e} already running`),"CONFLICT");return n.restartTimer&&(clearTimeout(n.restartTimer),n.restartTimer=void 0),n.manuallyStopped=!1,n.restartCount=0,n.breaker.reset(),n.failureReason=void 0,this.spawn(n,0),this.infoFor(n)}async stopByName(e){let n=this.entries.get(e);if(!n)throw Yr(new Error(`unknown ${this.adapter.kind}: ${e}`),"NOT_FOUND");n.manuallyStopped=!0,n.restartTimer&&(clearTimeout(n.restartTimer),n.restartTimer=void 0);let s=n.child;return s?(await this.terminate(n,s),this.infoFor(n)):this.infoFor(n)}async restartByName(e){return await this.stopByName(e),this.startByName(e)}register(e){if(this.entries.has(e.name))throw Yr(new Error(`${this.adapter.kind} ${e.name} already exists`),"CONFLICT");if(!this.context)throw new Error(`${this.managerName()}: setContext must be called before register`);let n=this.makeEntry(e);return this.entries.set(e.name,n),e.enabled&&this.spawn(n,0),this.infoFor(n)}async unregister(e){let n=this.entries.get(e);if(!n)throw Yr(new Error(`unknown ${this.adapter.kind}: ${e}`),"NOT_FOUND");n.manuallyStopped=!0,n.restartTimer&&(clearTimeout(n.restartTimer),n.restartTimer=void 0);let s=n.child;s&&await this.terminate(n,s);try{n.logStream?.end()}catch{}this.entries.delete(e)}async terminate(e,n){if(n.exitCode!==null||n.signalCode!==null)return;let s=new Promise(i=>{e.exitWaiters.push(i)});try{n.kill("SIGTERM")}catch{}let r=setTimeout(()=>{try{n.kill("SIGKILL")}catch{}},wd);typeof r.unref=="function"&&r.unref();try{await s}finally{clearTimeout(r)}}infoFor(e){let n;return e.failureReason!==void 0?n="failed":e.child?n="running":e.restartTimer?n="restarting":e.config.enabled?n="stopped":n="disabled",{name:e.config.name,status:n,pid:e.pid,enabled:e.config.enabled,restartCount:e.restartCount,startedAt:e.startedAt,lastExitCode:e.lastExitCode,logPath:this.adapter.paths.logFile(e.config.name),version:e.version,failureReason:e.failureReason}}makeEntry(e){return{config:e,child:void 0,logStream:void 0,restartTimer:void 0,pid:void 0,startedAt:void 0,restartCount:0,lastExitCode:void 0,manuallyStopped:!1,exitWaiters:[],version:void 0,processToken:void 0,breaker:new po(this.breakerOptions),failureReason:void 0}}async reapOrphans(){let e;try{e=await On.readdir(this.adapter.paths.dir())}catch(n){if(n.code==="ENOENT")return;throw n}for(let n of e){if(!n.endsWith(".pid"))continue;let s=Xu.join(this.adapter.paths.dir(),n),r;try{let i=await On.readFile(s,"utf8"),o=Number.parseInt(i.trim(),10);Number.isInteger(o)&&o>0&&(r=o)}catch{}if(typeof r=="number"&&bd(r)){try{process.kill(r,"SIGTERM")}catch{}let i=Date.now()+wd;for(;Date.now()<i&&bd(r);)await new Promise(o=>setTimeout(o,50));if(bd(r))try{process.kill(r,"SIGKILL")}catch{}}await On.unlink(s).catch(()=>{})}}spawn(e,n){if(this.stopping||e.manuallyStopped)return;let s=this.context;if(!s)throw new Error(`${this.managerName()}.spawn called before setContext`);let r=e.config,i=r.command.length>0?r.command:[r.name],o=Zs.createWriteStream(this.adapter.paths.logFile(r.name),{flags:"a"});o.write(`[hydra-acp] ${new Date().toISOString()} starting ${this.adapter.kind} ${r.name} (attempt ${n+1})
|
|
237
257
|
`);let a=this.tokenRegistry?.mint(r.name,this.adapter.tokenRole)??s.serviceToken;e.processToken=a,e.version=void 0;let d={...process.env,HYDRA_ACP_DAEMON_URL:s.daemonUrl,HYDRA_ACP_DAEMON_HOST:s.daemonHost,HYDRA_ACP_DAEMON_PORT:String(s.daemonPort),HYDRA_ACP_TOKEN:a,HYDRA_ACP_WS_URL:s.daemonWsUrl,HYDRA_ACP_HOME:s.hydraHome,[this.adapter.nameEnvVar]:r.name,...r.env},[c,...l]=i;if(c===void 0){o.write(`[hydra-acp] ${this.adapter.kind} ${r.name} has empty command
|
|
238
|
-
`),o.end();return}let f=[...l,...r.args],u;try{u=
|
|
258
|
+
`),o.end();return}let f=[...l,...r.args],u;try{u=Iw(c,f,{env:d,stdio:["ignore","pipe","pipe"],detached:!1})}catch(p){o.write(`[hydra-acp] failed to spawn ${r.name}: ${p.message}
|
|
239
259
|
`),o.end(),this.scheduleRestart(e,n);return}if(u.stdout&&u.stdout.pipe(o,{end:!1}),u.stderr&&u.stderr.pipe(o,{end:!1}),typeof u.pid=="number")try{Zs.writeFileSync(this.adapter.paths.pidFile(r.name),`${u.pid}
|
|
240
260
|
`,{encoding:"utf8",mode:384})}catch(p){o.write(`[hydra-acp] failed to write pid file for ${r.name}: ${p.message}
|
|
241
261
|
`)}e.child=u,e.logStream=o,e.pid=typeof u.pid=="number"?u.pid:void 0,e.startedAt=Date.now(),e.lastExitCode=void 0,u.on("error",p=>{o.write(`[hydra-acp] ${this.adapter.kind} ${r.name} error: ${p.message}
|
|
242
262
|
`)}),u.on("exit",(p,g)=>{try{Zs.unlinkSync(this.adapter.paths.pidFile(r.name))}catch{}o.write(`[hydra-acp] ${this.adapter.kind} ${r.name} exited code=${p??"null"} signal=${g??"null"}
|
|
243
263
|
`),e.child=void 0,e.pid=void 0,e.lastExitCode=typeof p=="number"?p:void 0,e.processToken&&(this.tokenRegistry?.revoke(r.name),e.processToken=void 0);let h=e.exitWaiters.splice(0);for(let v of h)v();if(this.stopping||e.manuallyStopped){try{o.end()}catch{}e.logStream=void 0;return}e.restartCount+=1;let w=e.breaker.recordExit(p,r.name,this.adapter.kind);if(typeof w=="object"){e.failureReason=w.tripped,o.write(`[hydra-acp] ${this.adapter.kind} ${r.name} circuit breaker tripped: ${w.tripped}
|
|
244
|
-
`);try{o.end()}catch{}e.logStream=void 0;return}this.scheduleRestart(e,n+1)})}scheduleRestart(e,n){if(this.stopping||e.manuallyStopped)return;let s=Math.min(this.restartBaseMs*2**Math.min(n,10),this.restartCapMs);e.restartTimer=setTimeout(()=>{e.restartTimer=void 0,this.spawn(e,n)},s),typeof e.restartTimer.unref=="function"&&e.restartTimer.unref()}managerName(){return this.adapter.kind==="extension"?"ExtensionManager":"TransformerManager"}};function bd(t){try{return process.kill(t,0),!0}catch{return!1}}function Yr(t,e){return t.code=e,t}ue();var
|
|
264
|
+
`);try{o.end()}catch{}e.logStream=void 0;return}this.scheduleRestart(e,n+1)})}scheduleRestart(e,n){if(this.stopping||e.manuallyStopped)return;let s=Math.min(this.restartBaseMs*2**Math.min(n,10),this.restartCapMs);e.restartTimer=setTimeout(()=>{e.restartTimer=void 0,this.spawn(e,n)},s),typeof e.restartTimer.unref=="function"&&e.restartTimer.unref()}managerName(){return this.adapter.kind==="extension"?"ExtensionManager":"TransformerManager"}};function bd(t){try{return process.kill(t,0),!0}catch{return!1}}function Yr(t,e){return t.code=e,t}ue();var xw={kind:"extension",nameEnvVar:"HYDRA_ACP_EXTENSION_NAME",tokenRole:"extension",paths:{dir:P.extensionsDir,logFile:P.extensionLogFile,pidFile:P.extensionPidFile}},mo=class extends Xs{constructor(e,n,s={}){super(e,xw,n,s)}};ue();var Aw={kind:"transformer",nameEnvVar:"HYDRA_ACP_TRANSFORMER_NAME",tokenRole:"transformer",paths:{dir:P.transformersDir,logFile:P.transformerLogFile,pidFile:P.transformerPidFile}},ho=class extends Xs{connected=new Map;constructor(e,n,s={}){super(e,Aw,n,s)}registerConnection(e,n,s){this.connected.set(e,{name:e,connection:n,intercepts:new Set(s)})}deregisterConnection(e){this.connected.delete(e)}resolveChain(e){let n=[];for(let s of e){let r=this.connected.get(s);r&&n.push(r)}return n}};var go=class{entries=new Map;changeHandlers=[];register(e,n,s){this.entries.set(e,{connection:n,commands:[...s]}),this.fireChanged()}clear(e){this.entries.delete(e)&&this.fireChanged()}get(e){return this.entries.get(e)}has(e){return this.entries.has(e)}list(){let e=[];for(let[n,s]of this.entries)for(let r of s.commands)e.push({name:n,command:r});return e}onChange(e){return this.changeHandlers.push(e),()=>{let n=this.changeHandlers.indexOf(e);n>=0&&this.changeHandlers.splice(n,1)}}fireChanged(){for(let e of this.changeHandlers)try{e()}catch{}}};ue();ue();import*as Gr from"fs/promises";import*as yo from"path";var Qr=t=>{process.stderr.write(t+`
|
|
245
265
|
`)};function vd(t){Qr=t??(e=>process.stderr.write(e+`
|
|
246
|
-
`))}async function Xu(t,e){let n=zt();if(!n)return;let s=await t.load(),r=new Map;for(let d of s.agents)r.set(d.id,d.version??"current");let i=e.activeAgentVersions(),o=yo.join(P.agentsDir(),n),a;try{a=await Gr.readdir(o,{withFileTypes:!0})}catch(d){let c=d;if(c.code==="ENOENT")return;Qr(`hydra-acp: prune: failed to read ${o}: ${c.message}`);return}for(let d of a){if(!d.isDirectory())continue;let c=d.name,l=r.get(c);if(l===void 0)continue;let f=i.get(c)??new Set,u=yo.join(o,c),p;try{p=await Gr.readdir(u,{withFileTypes:!0})}catch(g){Qr(`hydra-acp: prune: failed to read ${u}: ${g.message}`);continue}for(let g of p){if(!g.isDirectory())continue;let h=g.name;if(h===l||f.has(h)||h.includes(".partial-"))continue;let w=yo.join(u,h);try{await Gr.rm(w,{recursive:!0,force:!0}),Qr(`hydra-acp: pruned stale ${c} ${h} (${w})`)}catch(v){Qr(`hydra-acp: prune: failed to remove ${w}: ${v.message}`)}}}}function Zu(t){let e,n=!1,s=0,r=(a,d)=>{t.logger&&t.logger[a](`agent-sync: ${d}`)},i=async()=>{let a=[];try{let l=await t.registry.load();for(let f of l.agents)await Ja(f)==="yes"&&a.push(f.id)}catch(l){return r("warn",`registry load failed: ${l.message}`),t.intervalMs}if(a.length===0)return t.intervalMs;let d=s%a.length;s=(s+1)%a.length;let c=a[d];try{let{synced:l,skipped:f}=await t.manager.syncFromAgent(c);r("info",`${c}: synced ${l.length}, skipped ${f}`)}catch(l){r("warn",`${c}: ${l.message}`)}return Math.max(1,Math.floor(t.intervalMs/a.length))},o=a=>{n||(e=setTimeout(()=>{i().then(d=>{o(d)}).catch(d=>{r("warn",`tick crashed: ${d.message}`),o(t.intervalMs)})},a),e.unref())};return o(t.intervalMs),()=>{n=!0,e&&(clearTimeout(e),e=void 0)}}async function Id(t){let e=t.maxDeletions??200,n=(p,g)=>{t.logger&&t.logger[p](`session-gc: ${g}`)},s=Date.now(),r=t.maxAgeMs>0?s-t.maxAgeMs:Number.POSITIVE_INFINITY,i=await t.manager.list({includeNonInteractive:!0}).catch(p=>(n("warn",`manager.list failed: ${p.message}`),[])),o=[];for(let p of i){if(p.status!=="cold")continue;if((t.selection??"explicit")==="explicit"){if(p.interactive!==!1)continue}else if(p.interactive===!0)continue;let h=Date.parse(p.updatedAt);Number.isFinite(h)&&(t.maxAgeMs>0&&h>r||o.push({sessionId:p.sessionId,lastUsedMs:h}))}if(o.length===0)return t.verbose&&n("info","no candidates"),{considered:0,deleted:0,failed:0,deferred:0};o.sort((p,g)=>p.lastUsedMs-g.lastUsedMs);let a=o.slice(0,e),d=a[0]?.lastUsedMs,c=0,l=0;for(let{sessionId:p}of a)try{await t.manager.deleteRecord(p)&&(c+=1)}catch(g){l+=1,n("warn",`delete ${p} failed: ${g.message}`)}let f=o.length-a.length;if(t.verbose||c>0||l>0){let p=(t.selection??"explicit")==="unpromoted"?"unpromoted":"non-interactive";n("info",`swept ${c} ${p} session(s) older than ${Aw(t.maxAgeMs)}`+(l>0?`; ${l} failed`:"")+(f>0?`; ${f} deferred to next sweep`:""))}let u={considered:o.length,deleted:c,failed:l,deferred:f};return d!==void 0&&(u.oldestLastUsedMs=d),u}function ef(t){let e,n=!1,s=!1,r=i=>{n||(e=setTimeout(()=>{(async()=>{if(!s){s=!0;try{await Id({manager:t.manager,maxAgeMs:t.maxAgeMs,selection:"unpromoted",...t.maxDeletionsPerSweep!==void 0?{maxDeletions:t.maxDeletionsPerSweep}:{},...t.logger?{logger:t.logger}:{}})}finally{s=!1}}})().catch(a=>{t.logger?.warn(`session-gc: sweep crashed: ${a.message}`)}).finally(()=>{r(t.intervalMs)})},i),e.unref())};return r(t.intervalMs),()=>{n=!0,e&&(clearTimeout(e),e=void 0)}}function Aw(t){if(t<=0)return"any age";let e=t/(1440*60*1e3);if(e>=1)return`${e.toFixed(e>=10?0:1)}d`;let n=t/(3600*1e3);return`${n.toFixed(n>=10?0:1)}h`}Lt();wo();ue();is();import*as sf from"path";import{createHash as Rw,randomBytes as Tw,timingSafeEqual as Ew}from"crypto";var rf="hydra_session_",Pw=3600*24*30,tf=12,Mw=32,$w=50;function _w(){return sf.join(P.home(),"session-tokens.json")}function nf(t){return Rw("sha256").update(t).digest("hex")}function of(t){return Tw(t).toString("hex")}function Fw(){return of(tf).slice(0,tf*2)}function Ow(){return`${rf}${of(Mw)}`}var bo=class t{records=new Map;writeTimer=null;writeInflight=null;filePath;constructor(e,n){this.filePath=n;for(let s of e)this.records.set(s.hash,s)}static async load(){let e=[],n=_w(),s=await At(n);s&&Array.isArray(s.records)&&(e=s.records.filter(Lw));let r=new t(e,n);return r.sweepExpired(new Date)>0&&await r.flush(),r}async issue(e={}){let n=Ow(),s=nf(n),r=Fw(),i=new Date,o=e.ttlSec&&e.ttlSec>0?e.ttlSec:Pw,a=new Date(i.getTime()+o*1e3),d={id:r,hash:s,label:e.label,createdAt:i.toISOString(),expiresAt:a.toISOString(),lastUsedAt:i.toISOString()};return this.records.set(s,d),this.scheduleWrite(),{id:r,token:n,expiresAt:d.expiresAt}}async verify(e){if(typeof e!="string"||!e.startsWith(rf))return;let n=nf(e),s=this.records.get(n);if(!s)return;let r=Buffer.from(s.hash,"hex"),i=Buffer.from(n,"hex");if(r.length!==i.length||!Ew(r,i))return;let o=new Date;if(new Date(s.expiresAt).getTime()<=o.getTime()){this.records.delete(n),this.scheduleWrite();return}return s.lastUsedAt=o.toISOString(),this.scheduleWrite(),s.id}async revoke(e){for(let[n,s]of this.records)if(s.id===e)return this.records.delete(n),this.scheduleWrite(),!0;return!1}async revokeAll(){let e=this.records.size;return this.records.clear(),this.scheduleWrite(),e}list(){return Array.from(this.records.values()).map(({id:e,label:n,createdAt:s,expiresAt:r,lastUsedAt:i})=>({id:e,label:n,createdAt:s,expiresAt:r,lastUsedAt:i})).sort((e,n)=>n.createdAt.localeCompare(e.createdAt))}sweepExpired(e=new Date){let n=0;for(let[s,r]of this.records)new Date(r.expiresAt).getTime()<=e.getTime()&&(this.records.delete(s),n+=1);return n>0&&this.scheduleWrite(),n}async flush(){this.writeTimer&&(clearTimeout(this.writeTimer),this.writeTimer=null),await this.persist()}scheduleWrite(){this.writeTimer||(this.writeTimer=setTimeout(()=>{this.writeTimer=null,this.persist().catch(()=>{})},$w))}persist(){let e=(this.writeInflight??Promise.resolve()).catch(()=>{}).then(()=>ht(this.filePath,{records:Array.from(this.records.values())},{mode:384}));return this.writeInflight=e,e.catch(()=>{}).finally(()=>{this.writeInflight===e&&(this.writeInflight=null)}),e}};function Lw(t){if(!t||typeof t!="object")return!1;let e=t;return typeof e.id=="string"&&typeof e.hash=="string"&&typeof e.createdAt=="string"&&typeof e.expiresAt=="string"&&typeof e.lastUsedAt=="string"&&(e.label===void 0||typeof e.label=="string")}mt();var af="Bearer ",vo=class{constructor(e){this.token=e}token;async validate(e){return Bw(e,this.token)?"service":void 0}},Io=class{constructor(e){this.store=e}store;async validate(e){return this.store.verify(e)}},So=class{constructor(e){this.validators=e}validators;async validate(e){for(let n of this.validators){let s=await n.validate(e);if(s!==void 0)return s}}};function df(t){return async function(n,s){let r=n.headers.authorization;if(!r||!r.startsWith(af)){s.code(401).send({error:"Missing bearer token"});return}let i=r.slice(af.length).trim(),o=await t.validator.validate(i);if(!o){s.code(403).send({error:"Invalid token"});return}n.authIdentity=o}}function cf(t){let e=t.headers["sec-websocket-protocol"],n=Array.isArray(e)?e.join(","):e;if(n)for(let s of n.split(",")){let r=s.trim(),i="hydra-acp-token.";if(r.startsWith(i))return r.slice(i.length)}if(t.url)try{let r=new URL(t.url,"http://localhost").searchParams.get("token");if(r)return r}catch{return}}var ko=class{tokens=new Map;mint(e,n){let s=Fs();return this.tokens.set(s,{name:e,kind:n}),s}revoke(e){for(let[n,s]of this.tokens)s.name===e&&this.tokens.delete(n)}resolve(e){return this.tokens.get(e)}async validate(e){let n=this.tokens.get(e);if(n)return`${n.kind}:${n.name}`}};function Bw(t,e){if(t.length!==e.length)return!1;let n=0;for(let s=0;s<t.length;s+=1)n|=t.charCodeAt(s)^e.charCodeAt(s);return n===0}var xo=class{entries=new Map;maxFails;windowMs;constructor(e=10,n=900*1e3){this.maxFails=e,this.windowMs=n}isBlocked(e){let n=this.entries.get(e);return n?Date.now()-n.windowStart>this.windowMs?(this.entries.delete(e),!1):n.fails>=this.maxFails:!1}recordFailure(e){let n=Date.now(),s=this.entries.get(e);if(!s||n-s.windowStart>this.windowMs){this.entries.set(e,{fails:1,windowStart:n});return}s.fails+=1}recordSuccess(e){this.entries.delete(e)}};Ne();ls();Ro();import*as ei from"os";import*as kf from"path";xd();dt();Lt();Br();ps();function wb(t){let e=t.trim();if(e.length===0)return{operator:"OR",terms:[]};let n=/\w+:"[^"]*"|"[^"]*"|\S+/g,s=[],r;for(;(r=n.exec(e))!==null;)s.push(r[0]);let i="OR",o=!1,a=!1,d=[];for(let l of s){let f=l.toUpperCase();f==="AND"?o=!0:f==="OR"?a=!0:d.push(l)}o?i="AND":a&&(i="OR");let c=d.map(l=>bb(l)).filter(l=>l.term.length>0);return{operator:i,terms:c}}function bb(t){let e=/^(\w+):"([^"]*)"$/.exec(t);if(e)return{scope:yf(e[1]),term:e[2]};let n=/^"([^"]*)"$/.exec(t);if(n)return{scope:"all",term:n[1]};let s=/^(prompt|response|tool):([\s\S]*)$/i.exec(t);return s?{scope:yf(s[1]),term:s[2].trim()}:{scope:"all",term:t.trim()}}function yf(t){switch(t.toLowerCase()){case"prompt":return"user";case"response":return"agent";case"tool":return"tool";default:return"all"}}function vb(t,e){return t==="all"?!0:t==="user"?e==="user":t==="agent"?e==="agent"||e==="thought":e==="tool"||e==="tool-input"}var Ib=5,Sb=200,wf=30;async function If(t,e,n={}){let s=wb(e);if(s.terms.length===0)return{query:e,truncated:!1,results:[]};let r=n.maxSnippetsPerSession??Ib,i=n.maxSessions??Sb,o=n.sessionIds?new Set(n.sessionIds):null,a=await t.list(),d=o?a.filter(f=>o.has(f.sessionId)):a,c=[],l=!1;for(let f of d){if(c.length>=i){l=!0;break}let u=await t.loadHistory(f.sessionId).catch(()=>[]),p=kb(u,s,r);if(p.snippets.length===0)continue;let g={sessionId:f.sessionId,cwd:f.cwd,status:f.status,updatedAt:f.updatedAt,totalMatches:p.totalMatches,snippets:p.snippets};f.title!==void 0&&(g.title=f.title),c.push(g)}return{query:e,truncated:l,results:c}}function kb(t,e,n){if(e.terms.length===0)return{totalMatches:0,snippets:[]};let s=0,r=[];for(let{scope:i,term:o}of e.terms){let a=xb(t,o,i,n-r.length);if(e.operator==="AND"&&a.totalMatches===0)return{totalMatches:0,snippets:[]};s+=a.totalMatches,r.push(...a.snippets)}return{totalMatches:s,snippets:r}}function xb(t,e,n,s){let r=e.toLowerCase(),i=0,o=[];for(let a of t){let d=Ab(a).filter(c=>vb(n,c.kind));for(let c of d){let l=c.text.toLowerCase(),f=l.indexOf(r);if(f===-1)continue;let u=0;for(;f!==-1;)u++,f=l.indexOf(r,f+r.length);if(i+=u,o.length<s){let p=l.indexOf(r),g={kind:c.kind,text:Pb(c.text,p,r.length),recordedAt:a.recordedAt};c.toolName!==void 0&&(g.toolName=c.toolName),o.push(g)}}}return{totalMatches:i,snippets:o}}function Ab(t){if(t.method!=="session/update")return[];let e=t.params;if(!e||typeof e!="object"||Array.isArray(e))return[];let n=e.update;if(!n||typeof n!="object"||Array.isArray(n))return[];let s=n,r=typeof s.sessionUpdate=="string"?s.sessionUpdate:s.kind;if(typeof r!="string")return[];switch(r){case"agent_message_chunk":{let i=Eo(s.content);return i?[{kind:"agent",text:i}]:[]}case"agent_thought":case"agent_thought_chunk":{let i=typeof s.text=="string"?ct(s.text):Eo(s.content);return i?[{kind:"thought",text:i}]:[]}case"user_message_chunk":{if(Tb(s))return[];let i=Eo(s.content);return i?[{kind:"user",text:i}]:[]}case"prompt_received":{let i=Eb(s.prompt);return i?[{kind:"user",text:i}]:[]}case"tool_call":case"tool_call_update":return Cb(s);default:return[]}}function Cb(t){let e=bf(t,"name"),n=bf(t,"title"),s=[];if(n!==void 0){let a=ke(n);if(a.length>0){let d={kind:"tool",text:a};e!==void 0&&(d.toolName=e),s.push(d)}}if(e!==void 0&&e!==n){let a=ke(e);a.length>0&&s.push({kind:"tool",toolName:e,text:a})}let r=t.rawInput;if(r&&typeof r=="object"){let a=vf(r);if(a.length>0){let d={kind:"tool-input",text:ke(a)};e!==void 0&&(d.toolName=e),s.push(d)}}let i=t.locations;if(Array.isArray(i)&&i.length>0){let a=vf(i);if(a.length>0){let d={kind:"tool-input",text:ke(a)};e!==void 0&&(d.toolName=e),s.push(d)}}let o=Rb(t);if(o!==null){let a={kind:"tool",text:o};e!==void 0&&(a.toolName=e),s.push(a)}return s}function Rb(t){let e=t.content;if(Array.isArray(e))for(let s of e){if(!s||typeof s!="object")continue;let i=s.content;if(!i||typeof i!="object")continue;let o=i;if(o.type==="text"&&typeof o.text=="string"){let a=ke(o.text);if(a.length>0)return a}}let n=t.rawOutput;if(n&&typeof n=="object"){let s=n.error;if(typeof s=="string"){let r=ke(s);if(r.length>0)return r}}return null}function Tb(t){let e=t._meta;if(!e||typeof e!="object"||Array.isArray(e))return!1;let n=e["hydra-acp"];return!n||typeof n!="object"||Array.isArray(n)?!1:n.compatFor==="prompt_received"}function Eo(t){if(typeof t=="string")return ct(t);if(!t||typeof t!="object"||Array.isArray(t))return"";let e=t;return typeof e.text=="string"?ct(e.text):""}function Eb(t){if(!Array.isArray(t))return"";let e=[];for(let n of t){let s=Eo(n);s.length>0&&e.push(s)}return e.join("")}function bf(t,e){let n=t[e];return typeof n=="string"?n:void 0}function vf(t){try{return JSON.stringify(t)}catch{return""}}function Pb(t,e,n){let s=t.replace(/\s+/g," ").trim();if(s.length===0)return"";let r=s.toLowerCase(),i=t.slice(e,e+n).toLowerCase().replace(/\s+/g," ").trim(),o=i.length>0?r.indexOf(i):0;o===-1&&(o=0);let a=Math.max(0,o-wf),d=Math.min(s.length,o+i.length+wf),c=a>0?"\u2026":"",l=d<s.length?"\u2026":"";return`${c}${s.slice(a,d)}${l}`}function Sf(t){if(t.publicHost&&t.publicHost.length>0)return t.publicHost;if(t.host&&!on(t.host))return t.port!==void 0?`${t.host}:${t.port}`:t.host}function xf(t,e,n){t.get("/v1/sessions",async s=>{let r=s.query,i=r?.includeNonInteractive==="1"||r?.includeNonInteractive==="true";return{sessions:await e.list({cwd:r?.cwd,includeNonInteractive:i})}}),t.post("/v1/sessions/search",async(s,r)=>{let i=s.body??{},o=typeof i.q=="string"?i.q:"";if(o.trim().length===0)return r.code(400).send({error:"q is required"}),r;let a=Array.isArray(i.sessionIds)?i.sessionIds.filter(c=>typeof c=="string"&&c.length>0):void 0;return await If(e,o,{sessionIds:a})}),t.post("/v1/sessions",async(s,r)=>{let i=s.body??{},o=Ft(i.cwd??n.cwd),a=i.agentId??n.agentId;try{let d=await e.create({cwd:o,agentId:a,mcpServers:i.mcpServers});r.code(201).send({sessionId:d.sessionId,agentId:d.agentId,cwd:d.cwd})}catch(d){r.code(500).send({error:d.message})}}),t.post("/v1/sessions/collect",async(s,r)=>{let i=s.body??{},o=typeof i.maxAgeDays=="number"&&i.maxAgeDays>0?i.maxAgeDays*24*60*60*1e3:0,a=typeof i.limit=="number"&&i.limit>0?i.limit:1e3,d=i.selection==="explicit"||i.selection==="unpromoted"?i.selection:"unpromoted";try{let c=await Id({manager:e,maxAgeMs:o,maxDeletions:a,selection:d,verbose:!1});r.code(200).send(c)}catch(c){r.code(500).send({error:c.message})}}),t.post("/v1/sessions/:id/kill",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=e.get(o);if(a){a.close({deleteRecord:!1}).catch(()=>{}),r.code(202).send();return}if(!await e.hasRecord(o)){r.code(404).send({error:"session not found"});return}r.code(204).send()}),t.post("/v1/sessions/:id/stdin/open",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=e.get(o);if(!a)return r.code(404).send({error:"session not found"}),r;let d=s.body??{},c={};(d.mode==="memory"||d.mode==="file")&&(c.mode=d.mode),typeof d.capacityBytes=="number"&&(c.capacityBytes=d.capacityBytes),typeof d.fileCapBytes=="number"&&(c.fileCapBytes=d.fileCapBytes),(c.mode??"memory")==="file"&&(c.filePathFor=l=>kf.join(ei.tmpdir(),`hydra-acp-stdin-${l}.log`));try{return a.openStream(c)}catch(l){return r.code(409).send({error:l.message}),r}}),t.post("/v1/sessions/:id/stdin",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=e.get(o);if(!a)return r.code(404).send({error:"session not found"}),r;let d=s.body??{},c=typeof d.chunk=="string"?d.chunk:"",l=d.eof===!0;try{return a.streamWrite(c,l)}catch(f){return r.code(409).send({error:f.message}),r}}),t.patch("/v1/sessions/:id",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=s.body??{};if(a.priority!==void 0){let c=a.priority,l;if(c===null||c===0)l=void 0;else if(typeof c=="number"&&Number.isInteger(c)&&c>0)l=c;else{r.code(400).send({error:"priority must be a non-negative integer (or null to clear)"});return}if(!await e.setPriority(o,l)){r.code(404).send({error:"session not found"});return}r.code(204).send();return}if(a.regen===!0){if(!(e.get(o)!==void 0||await e.hasRecord(o))){r.code(404).send({error:"session not found"});return}e.scheduleSynopsis(o),r.code(202).send();return}if(typeof a.title!="string"||a.title.trim().length===0){r.code(400).send({error:"title must be a non-empty string"});return}if(!await e.setTitle(o,a.title)){r.code(404).send({error:"session not found"});return}r.code(204).send()}),t.delete("/v1/sessions/:id",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=e.get(o);if(a){await a.close({deleteRecord:!0}),r.code(204).send();return}if(!await e.deleteRecord(o)){r.code(404).send({error:"session not found"});return}r.code(204).send()}),t.get("/v1/sessions/:id/export",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=s.query?.tools,d=a==="references"?"references":_u(a),c=await e.exportBundle(o,d==="references"?{tools:"references"}:{});if(!c){r.code(404).send({error:"session not found"});return}let l=Kr({record:c.record,history:d==="summary"?Fu(c.history,"summary"):c.history,promptHistory:c.promptHistory.length>0?c.promptHistory:void 0,...c.toolBlobs!==void 0?{toolBlobs:c.toolBlobs}:{},hydraVersion:me,machine:ei.hostname(),hydraHost:Sf(n)}),f=new Date().toISOString().replace(/[:.]/g,"-");r.header("Content-Disposition",`attachment; filename="${o}-${f}.hydra"`),r.code(200).send(l)}),t.get("/v1/sessions/:id/diff",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=await e.exportBundle(o);if(!a){r.code(404).send({error:"session not found"});return}let d=s.query??{},c=d.fold==="true"||d.fold==="1",l=typeof d.paths=="string"&&d.paths.length>0?new Set(d.paths.split(",").map(u=>u.trim()).filter(u=>u.length>0)):void 0,f=tr(a.history);l&&(f=f.filter(u=>l.has(u.path))),c&&(f=f.map(u=>({...u,hunks:nr(u.hunks)}))),r.code(200).send(f)}),t.get("/v1/sessions/:id/tools/:hash",async(s,r)=>{let i=s.params,o=await e.resolveCanonicalId(i.id)??i.id,a=await e.loadToolBlob(o,i.hash);if(a===null){r.code(404).send({error:"tool blob not found"});return}r.header("Content-Type","text/plain; charset=utf-8"),r.code(200).send(a)}),t.get("/v1/sessions/:id/transcript",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=await e.exportBundle(o);if(!a){r.code(404).send({error:"session not found"});return}let d=Kr({record:a.record,history:a.history,promptHistory:a.promptHistory.length>0?a.promptHistory:void 0,hydraVersion:me,machine:ei.hostname(),hydraHost:Sf(n)});r.header("Content-Type","text/markdown; charset=utf-8"),r.code(200).send(To(d))}),t.post("/v1/sessions/:id/fork",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=s.body??{},d={};if(a.forkAt!==void 0){if(typeof a.forkAt!="string"||a.forkAt.length===0){r.code(400).send({error:"forkAt must be a non-empty string"});return}d.forkAt=a.forkAt}if(a.cwd!==void 0){if(typeof a.cwd!="string"||a.cwd.length===0){r.code(400).send({error:"cwd must be a non-empty string"});return}d.cwd=Ft(a.cwd)}if(a.agentId!==void 0){if(typeof a.agentId!="string"||a.agentId.length===0){r.code(400).send({error:"agentId must be a non-empty string"});return}d.agentId=a.agentId}try{let c=await e.forkSession(o,d);r.code(201).send(c)}catch(c){let l=c;if(l.code===B.SessionNotFound){r.code(404).send({error:l.message});return}if(l.code===B.InvalidParams||l.code===B.AgentNotInstalled){r.code(400).send({error:l.message});return}r.code(500).send({error:l.message})}}),t.post("/v1/sessions/import",async(s,r)=>{let i=s.body??{};if(i.bundle===void 0){r.code(400).send({error:"missing bundle"});return}let o;if(i.cwd!==void 0){if(typeof i.cwd!="string"||i.cwd.length===0){r.code(400).send({error:"cwd must be a non-empty string"});return}o=i.cwd}let a;try{a=Bt(i.bundle)}catch(d){r.code(400).send({error:"invalid bundle",details:d.message});return}try{let d=await e.importBundle(a,{replace:i.replace===!0,...o!==void 0?{cwd:o}:{}});r.code(201).send(d)}catch(d){let c=d;if(c.code===B.BundleAlreadyImported){r.code(409).send({error:"bundle already imported",existingSessionId:c.existingSessionId});return}r.code(500).send({error:c.message})}}),t.get("/v1/sessions/:id/history",async(s,r)=>{let i=s.params.id,o=s.query,a=o?.follow==="1"||o?.follow==="true",d=await e.resolveCanonicalId(i)??i,c=e.get(d),l,f,u=!1,p=[];if(c)a&&(f=c.onBroadcast(h=>{r.raw.writableEnded||(u?r.raw.write(JSON.stringify(h)+`
|
|
266
|
+
`))}async function Zu(t,e){let n=zt();if(!n)return;let s=await t.load(),r=new Map;for(let d of s.agents)r.set(d.id,d.version??"current");let i=e.activeAgentVersions(),o=yo.join(P.agentsDir(),n),a;try{a=await Gr.readdir(o,{withFileTypes:!0})}catch(d){let c=d;if(c.code==="ENOENT")return;Qr(`hydra-acp: prune: failed to read ${o}: ${c.message}`);return}for(let d of a){if(!d.isDirectory())continue;let c=d.name,l=r.get(c);if(l===void 0)continue;let f=i.get(c)??new Set,u=yo.join(o,c),p;try{p=await Gr.readdir(u,{withFileTypes:!0})}catch(g){Qr(`hydra-acp: prune: failed to read ${u}: ${g.message}`);continue}for(let g of p){if(!g.isDirectory())continue;let h=g.name;if(h===l||f.has(h)||h.includes(".partial-"))continue;let w=yo.join(u,h);try{await Gr.rm(w,{recursive:!0,force:!0}),Qr(`hydra-acp: pruned stale ${c} ${h} (${w})`)}catch(v){Qr(`hydra-acp: prune: failed to remove ${w}: ${v.message}`)}}}}function ef(t){let e,n=!1,s=0,r=(a,d)=>{t.logger&&t.logger[a](`agent-sync: ${d}`)},i=async()=>{let a=[];try{let l=await t.registry.load();for(let f of l.agents)await Ja(f)==="yes"&&a.push(f.id)}catch(l){return r("warn",`registry load failed: ${l.message}`),t.intervalMs}if(a.length===0)return t.intervalMs;let d=s%a.length;s=(s+1)%a.length;let c=a[d];try{let{synced:l,skipped:f}=await t.manager.syncFromAgent(c);r("info",`${c}: synced ${l.length}, skipped ${f}`)}catch(l){r("warn",`${c}: ${l.message}`)}return Math.max(1,Math.floor(t.intervalMs/a.length))},o=a=>{n||(e=setTimeout(()=>{i().then(d=>{o(d)}).catch(d=>{r("warn",`tick crashed: ${d.message}`),o(t.intervalMs)})},a),e.unref())};return o(t.intervalMs),()=>{n=!0,e&&(clearTimeout(e),e=void 0)}}async function Id(t){let e=t.maxDeletions??200,n=(p,g)=>{t.logger&&t.logger[p](`session-gc: ${g}`)},s=Date.now(),r=t.maxAgeMs>0?s-t.maxAgeMs:Number.POSITIVE_INFINITY,i=await t.manager.list({includeNonInteractive:!0}).catch(p=>(n("warn",`manager.list failed: ${p.message}`),[])),o=[];for(let p of i){if(p.status!=="cold")continue;if((t.selection??"explicit")==="explicit"){if(p.interactive!==!1)continue}else if(p.interactive===!0)continue;let h=Date.parse(p.updatedAt);Number.isFinite(h)&&(t.maxAgeMs>0&&h>r||o.push({sessionId:p.sessionId,lastUsedMs:h}))}if(o.length===0)return t.verbose&&n("info","no candidates"),{considered:0,deleted:0,failed:0,deferred:0};o.sort((p,g)=>p.lastUsedMs-g.lastUsedMs);let a=o.slice(0,e),d=a[0]?.lastUsedMs,c=0,l=0;for(let{sessionId:p}of a)try{await t.manager.deleteRecord(p)&&(c+=1)}catch(g){l+=1,n("warn",`delete ${p} failed: ${g.message}`)}let f=o.length-a.length;if(t.verbose||c>0||l>0){let p=(t.selection??"explicit")==="unpromoted"?"unpromoted":"non-interactive";n("info",`swept ${c} ${p} session(s) older than ${Cw(t.maxAgeMs)}`+(l>0?`; ${l} failed`:"")+(f>0?`; ${f} deferred to next sweep`:""))}let u={considered:o.length,deleted:c,failed:l,deferred:f};return d!==void 0&&(u.oldestLastUsedMs=d),u}function tf(t){let e,n=!1,s=!1,r=i=>{n||(e=setTimeout(()=>{(async()=>{if(!s){s=!0;try{await Id({manager:t.manager,maxAgeMs:t.maxAgeMs,selection:"unpromoted",...t.maxDeletionsPerSweep!==void 0?{maxDeletions:t.maxDeletionsPerSweep}:{},...t.logger?{logger:t.logger}:{}})}finally{s=!1}}})().catch(a=>{t.logger?.warn(`session-gc: sweep crashed: ${a.message}`)}).finally(()=>{r(t.intervalMs)})},i),e.unref())};return r(t.intervalMs),()=>{n=!0,e&&(clearTimeout(e),e=void 0)}}function Cw(t){if(t<=0)return"any age";let e=t/(1440*60*1e3);if(e>=1)return`${e.toFixed(e>=10?0:1)}d`;let n=t/(3600*1e3);return`${n.toFixed(n>=10?0:1)}h`}Lt();wo();ue();os();import*as rf from"path";import{createHash as Tw,randomBytes as Ew,timingSafeEqual as Pw}from"crypto";var of="hydra_session_",Mw=3600*24*30,nf=12,$w=32,_w=50;function Fw(){return rf.join(P.home(),"session-tokens.json")}function sf(t){return Tw("sha256").update(t).digest("hex")}function af(t){return Ew(t).toString("hex")}function Ow(){return af(nf).slice(0,nf*2)}function Lw(){return`${of}${af($w)}`}var bo=class t{records=new Map;writeTimer=null;writeInflight=null;filePath;constructor(e,n){this.filePath=n;for(let s of e)this.records.set(s.hash,s)}static async load(){let e=[],n=Fw(),s=await At(n);s&&Array.isArray(s.records)&&(e=s.records.filter(Bw));let r=new t(e,n);return r.sweepExpired(new Date)>0&&await r.flush(),r}async issue(e={}){let n=Lw(),s=sf(n),r=Ow(),i=new Date,o=e.ttlSec&&e.ttlSec>0?e.ttlSec:Mw,a=new Date(i.getTime()+o*1e3),d={id:r,hash:s,label:e.label,createdAt:i.toISOString(),expiresAt:a.toISOString(),lastUsedAt:i.toISOString()};return this.records.set(s,d),this.scheduleWrite(),{id:r,token:n,expiresAt:d.expiresAt}}async verify(e){if(typeof e!="string"||!e.startsWith(of))return;let n=sf(e),s=this.records.get(n);if(!s)return;let r=Buffer.from(s.hash,"hex"),i=Buffer.from(n,"hex");if(r.length!==i.length||!Pw(r,i))return;let o=new Date;if(new Date(s.expiresAt).getTime()<=o.getTime()){this.records.delete(n),this.scheduleWrite();return}return s.lastUsedAt=o.toISOString(),this.scheduleWrite(),s.id}async revoke(e){for(let[n,s]of this.records)if(s.id===e)return this.records.delete(n),this.scheduleWrite(),!0;return!1}async revokeAll(){let e=this.records.size;return this.records.clear(),this.scheduleWrite(),e}list(){return Array.from(this.records.values()).map(({id:e,label:n,createdAt:s,expiresAt:r,lastUsedAt:i})=>({id:e,label:n,createdAt:s,expiresAt:r,lastUsedAt:i})).sort((e,n)=>n.createdAt.localeCompare(e.createdAt))}sweepExpired(e=new Date){let n=0;for(let[s,r]of this.records)new Date(r.expiresAt).getTime()<=e.getTime()&&(this.records.delete(s),n+=1);return n>0&&this.scheduleWrite(),n}async flush(){this.writeTimer&&(clearTimeout(this.writeTimer),this.writeTimer=null),await this.persist()}scheduleWrite(){this.writeTimer||(this.writeTimer=setTimeout(()=>{this.writeTimer=null,this.persist().catch(()=>{})},_w))}persist(){let e=(this.writeInflight??Promise.resolve()).catch(()=>{}).then(()=>ht(this.filePath,{records:Array.from(this.records.values())},{mode:384}));return this.writeInflight=e,e.catch(()=>{}).finally(()=>{this.writeInflight===e&&(this.writeInflight=null)}),e}};function Bw(t){if(!t||typeof t!="object")return!1;let e=t;return typeof e.id=="string"&&typeof e.hash=="string"&&typeof e.createdAt=="string"&&typeof e.expiresAt=="string"&&typeof e.lastUsedAt=="string"&&(e.label===void 0||typeof e.label=="string")}mt();var df="Bearer ",vo=class{constructor(e){this.token=e}token;async validate(e){return Nw(e,this.token)?"service":void 0}},Io=class{constructor(e){this.store=e}store;async validate(e){return this.store.verify(e)}},So=class{constructor(e){this.validators=e}validators;async validate(e){for(let n of this.validators){let s=await n.validate(e);if(s!==void 0)return s}}};function cf(t){return async function(n,s){let r=n.headers.authorization;if(!r||!r.startsWith(df)){s.code(401).send({error:"Missing bearer token"});return}let i=r.slice(df.length).trim(),o=await t.validator.validate(i);if(!o){s.code(403).send({error:"Invalid token"});return}n.authIdentity=o}}function lf(t){let e=t.headers["sec-websocket-protocol"],n=Array.isArray(e)?e.join(","):e;if(n)for(let s of n.split(",")){let r=s.trim(),i="hydra-acp-token.";if(r.startsWith(i))return r.slice(i.length)}if(t.url)try{let r=new URL(t.url,"http://localhost").searchParams.get("token");if(r)return r}catch{return}}var ko=class{tokens=new Map;mint(e,n){let s=Os();return this.tokens.set(s,{name:e,kind:n}),s}revoke(e){for(let[n,s]of this.tokens)s.name===e&&this.tokens.delete(n)}resolve(e){return this.tokens.get(e)}async validate(e){let n=this.tokens.get(e);if(n)return`${n.kind}:${n.name}`}};function Nw(t,e){if(t.length!==e.length)return!1;let n=0;for(let s=0;s<t.length;s+=1)n|=t.charCodeAt(s)^e.charCodeAt(s);return n===0}var xo=class{entries=new Map;maxFails;windowMs;constructor(e=10,n=900*1e3){this.maxFails=e,this.windowMs=n}isBlocked(e){let n=this.entries.get(e);return n?Date.now()-n.windowStart>this.windowMs?(this.entries.delete(e),!1):n.fails>=this.maxFails:!1}recordFailure(e){let n=Date.now(),s=this.entries.get(e);if(!s||n-s.windowStart>this.windowMs){this.entries.set(e,{fails:1,windowStart:n});return}s.fails+=1}recordSuccess(e){this.entries.delete(e)}};Ne();us();Ro();import*as ei from"os";import*as xf from"path";xd();dt();Lt();Br();ms();function bb(t){let e=t.trim();if(e.length===0)return{operator:"OR",terms:[]};let n=/\w+:"[^"]*"|"[^"]*"|\S+/g,s=[],r;for(;(r=n.exec(e))!==null;)s.push(r[0]);let i="OR",o=!1,a=!1,d=[];for(let l of s){let f=l.toUpperCase();f==="AND"?o=!0:f==="OR"?a=!0:d.push(l)}o?i="AND":a&&(i="OR");let c=d.map(l=>vb(l)).filter(l=>l.term.length>0);return{operator:i,terms:c}}function vb(t){let e=/^(\w+):"([^"]*)"$/.exec(t);if(e)return{scope:wf(e[1]),term:e[2]};let n=/^"([^"]*)"$/.exec(t);if(n)return{scope:"all",term:n[1]};let s=/^(prompt|response|tool):([\s\S]*)$/i.exec(t);return s?{scope:wf(s[1]),term:s[2].trim()}:{scope:"all",term:t.trim()}}function wf(t){switch(t.toLowerCase()){case"prompt":return"user";case"response":return"agent";case"tool":return"tool";default:return"all"}}function Ib(t,e){return t==="all"?!0:t==="user"?e==="user":t==="agent"?e==="agent"||e==="thought":e==="tool"||e==="tool-input"}var Sb=5,kb=200,bf=30;async function Sf(t,e,n={}){let s=bb(e);if(s.terms.length===0)return{query:e,truncated:!1,results:[]};let r=n.maxSnippetsPerSession??Sb,i=n.maxSessions??kb,o=n.sessionIds?new Set(n.sessionIds):null,a=await t.list(),d=o?a.filter(f=>o.has(f.sessionId)):a,c=[],l=!1;for(let f of d){if(c.length>=i){l=!0;break}let u=await t.loadHistory(f.sessionId).catch(()=>[]),p=xb(u,s,r);if(p.snippets.length===0)continue;let g={sessionId:f.sessionId,cwd:f.cwd,status:f.status,updatedAt:f.updatedAt,totalMatches:p.totalMatches,snippets:p.snippets};f.title!==void 0&&(g.title=f.title),c.push(g)}return{query:e,truncated:l,results:c}}function xb(t,e,n){if(e.terms.length===0)return{totalMatches:0,snippets:[]};let s=0,r=[];for(let{scope:i,term:o}of e.terms){let a=Ab(t,o,i,n-r.length);if(e.operator==="AND"&&a.totalMatches===0)return{totalMatches:0,snippets:[]};s+=a.totalMatches,r.push(...a.snippets)}return{totalMatches:s,snippets:r}}function Ab(t,e,n,s){let r=e.toLowerCase(),i=0,o=[];for(let a of t){let d=Cb(a).filter(c=>Ib(n,c.kind));for(let c of d){let l=c.text.toLowerCase(),f=l.indexOf(r);if(f===-1)continue;let u=0;for(;f!==-1;)u++,f=l.indexOf(r,f+r.length);if(i+=u,o.length<s){let p=l.indexOf(r),g={kind:c.kind,text:Mb(c.text,p,r.length),recordedAt:a.recordedAt};c.toolName!==void 0&&(g.toolName=c.toolName),o.push(g)}}}return{totalMatches:i,snippets:o}}function Cb(t){if(t.method!=="session/update")return[];let e=t.params;if(!e||typeof e!="object"||Array.isArray(e))return[];let n=e.update;if(!n||typeof n!="object"||Array.isArray(n))return[];let s=n,r=typeof s.sessionUpdate=="string"?s.sessionUpdate:s.kind;if(typeof r!="string")return[];switch(r){case"agent_message_chunk":{let i=Eo(s.content);return i?[{kind:"agent",text:i}]:[]}case"agent_thought":case"agent_thought_chunk":{let i=typeof s.text=="string"?ct(s.text):Eo(s.content);return i?[{kind:"thought",text:i}]:[]}case"user_message_chunk":{if(Eb(s))return[];let i=Eo(s.content);return i?[{kind:"user",text:i}]:[]}case"prompt_received":{let i=Pb(s.prompt);return i?[{kind:"user",text:i}]:[]}case"tool_call":case"tool_call_update":return Rb(s);default:return[]}}function Rb(t){let e=vf(t,"name"),n=vf(t,"title"),s=[];if(n!==void 0){let a=ke(n);if(a.length>0){let d={kind:"tool",text:a};e!==void 0&&(d.toolName=e),s.push(d)}}if(e!==void 0&&e!==n){let a=ke(e);a.length>0&&s.push({kind:"tool",toolName:e,text:a})}let r=t.rawInput;if(r&&typeof r=="object"){let a=If(r);if(a.length>0){let d={kind:"tool-input",text:ke(a)};e!==void 0&&(d.toolName=e),s.push(d)}}let i=t.locations;if(Array.isArray(i)&&i.length>0){let a=If(i);if(a.length>0){let d={kind:"tool-input",text:ke(a)};e!==void 0&&(d.toolName=e),s.push(d)}}let o=Tb(t);if(o!==null){let a={kind:"tool",text:o};e!==void 0&&(a.toolName=e),s.push(a)}return s}function Tb(t){let e=t.content;if(Array.isArray(e))for(let s of e){if(!s||typeof s!="object")continue;let i=s.content;if(!i||typeof i!="object")continue;let o=i;if(o.type==="text"&&typeof o.text=="string"){let a=ke(o.text);if(a.length>0)return a}}let n=t.rawOutput;if(n&&typeof n=="object"){let s=n.error;if(typeof s=="string"){let r=ke(s);if(r.length>0)return r}}return null}function Eb(t){let e=t._meta;if(!e||typeof e!="object"||Array.isArray(e))return!1;let n=e["hydra-acp"];return!n||typeof n!="object"||Array.isArray(n)?!1:n.compatFor==="prompt_received"}function Eo(t){if(typeof t=="string")return ct(t);if(!t||typeof t!="object"||Array.isArray(t))return"";let e=t;return typeof e.text=="string"?ct(e.text):""}function Pb(t){if(!Array.isArray(t))return"";let e=[];for(let n of t){let s=Eo(n);s.length>0&&e.push(s)}return e.join("")}function vf(t,e){let n=t[e];return typeof n=="string"?n:void 0}function If(t){try{return JSON.stringify(t)}catch{return""}}function Mb(t,e,n){let s=t.replace(/\s+/g," ").trim();if(s.length===0)return"";let r=s.toLowerCase(),i=t.slice(e,e+n).toLowerCase().replace(/\s+/g," ").trim(),o=i.length>0?r.indexOf(i):0;o===-1&&(o=0);let a=Math.max(0,o-bf),d=Math.min(s.length,o+i.length+bf),c=a>0?"\u2026":"",l=d<s.length?"\u2026":"";return`${c}${s.slice(a,d)}${l}`}function kf(t){if(t.publicHost&&t.publicHost.length>0)return t.publicHost;if(t.host&&!on(t.host))return t.port!==void 0?`${t.host}:${t.port}`:t.host}function Af(t,e,n){t.get("/v1/sessions",async s=>{let r=s.query,i=r?.includeNonInteractive==="1"||r?.includeNonInteractive==="true";return{sessions:await e.list({cwd:r?.cwd,includeNonInteractive:i})}}),t.post("/v1/sessions/search",async(s,r)=>{let i=s.body??{},o=typeof i.q=="string"?i.q:"";if(o.trim().length===0)return r.code(400).send({error:"q is required"}),r;let a=Array.isArray(i.sessionIds)?i.sessionIds.filter(c=>typeof c=="string"&&c.length>0):void 0;return await Sf(e,o,{sessionIds:a})}),t.post("/v1/sessions",async(s,r)=>{let i=s.body??{},o=Ft(i.cwd??n.cwd),a=i.agentId??n.agentId;try{let d=await e.create({cwd:o,agentId:a,mcpServers:i.mcpServers});r.code(201).send({sessionId:d.sessionId,agentId:d.agentId,cwd:d.cwd})}catch(d){r.code(500).send({error:d.message})}}),t.post("/v1/sessions/collect",async(s,r)=>{let i=s.body??{},o=typeof i.maxAgeDays=="number"&&i.maxAgeDays>0?i.maxAgeDays*24*60*60*1e3:0,a=typeof i.limit=="number"&&i.limit>0?i.limit:1e3,d=i.selection==="explicit"||i.selection==="unpromoted"?i.selection:"unpromoted";try{let c=await Id({manager:e,maxAgeMs:o,maxDeletions:a,selection:d,verbose:!1});r.code(200).send(c)}catch(c){r.code(500).send({error:c.message})}}),t.post("/v1/sessions/:id/kill",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=e.get(o);if(a){a.close({deleteRecord:!1}).catch(()=>{}),r.code(202).send();return}if(!await e.hasRecord(o)){r.code(404).send({error:"session not found"});return}r.code(204).send()}),t.post("/v1/sessions/:id/stdin/open",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=e.get(o);if(!a)return r.code(404).send({error:"session not found"}),r;let d=s.body??{},c={};(d.mode==="memory"||d.mode==="file")&&(c.mode=d.mode),typeof d.capacityBytes=="number"&&(c.capacityBytes=d.capacityBytes),typeof d.fileCapBytes=="number"&&(c.fileCapBytes=d.fileCapBytes),(c.mode??"memory")==="file"&&(c.filePathFor=l=>xf.join(ei.tmpdir(),`hydra-acp-stdin-${l}.log`));try{return a.openStream(c)}catch(l){return r.code(409).send({error:l.message}),r}}),t.post("/v1/sessions/:id/stdin",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=e.get(o);if(!a)return r.code(404).send({error:"session not found"}),r;let d=s.body??{},c=typeof d.chunk=="string"?d.chunk:"",l=d.eof===!0;try{return a.streamWrite(c,l)}catch(f){return r.code(409).send({error:f.message}),r}}),t.patch("/v1/sessions/:id",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=s.body??{};if(a.priority!==void 0){let c=a.priority,l;if(c===null||c===0)l=void 0;else if(typeof c=="number"&&Number.isInteger(c)&&c>0)l=c;else{r.code(400).send({error:"priority must be a non-negative integer (or null to clear)"});return}if(!await e.setPriority(o,l)){r.code(404).send({error:"session not found"});return}r.code(204).send();return}if(a.regen===!0){if(!(e.get(o)!==void 0||await e.hasRecord(o))){r.code(404).send({error:"session not found"});return}e.scheduleSynopsis(o),r.code(202).send();return}if(typeof a.title!="string"||a.title.trim().length===0){r.code(400).send({error:"title must be a non-empty string"});return}if(!await e.setTitle(o,a.title)){r.code(404).send({error:"session not found"});return}r.code(204).send()}),t.delete("/v1/sessions/:id",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=e.get(o);if(a){await a.close({deleteRecord:!0}),r.code(204).send();return}if(!await e.deleteRecord(o)){r.code(404).send({error:"session not found"});return}r.code(204).send()}),t.get("/v1/sessions/:id/export",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=s.query?.tools,d=a==="references"?"references":Fu(a),c=await e.exportBundle(o,d==="references"?{tools:"references"}:{});if(!c){r.code(404).send({error:"session not found"});return}let l=Kr({record:c.record,history:d==="summary"?Ou(c.history,"summary"):c.history,promptHistory:c.promptHistory.length>0?c.promptHistory:void 0,...c.toolBlobs!==void 0?{toolBlobs:c.toolBlobs}:{},hydraVersion:me,machine:ei.hostname(),hydraHost:kf(n)}),f=new Date().toISOString().replace(/[:.]/g,"-");r.header("Content-Disposition",`attachment; filename="${o}-${f}.hydra"`),r.code(200).send(l)}),t.get("/v1/sessions/:id/diff",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=await e.exportBundle(o);if(!a){r.code(404).send({error:"session not found"});return}let d=s.query??{},c=d.fold==="true"||d.fold==="1",l=typeof d.paths=="string"&&d.paths.length>0?new Set(d.paths.split(",").map(u=>u.trim()).filter(u=>u.length>0)):void 0,f=tr(a.history);l&&(f=f.filter(u=>l.has(u.path))),c&&(f=f.map(u=>({...u,hunks:nr(u.hunks)}))),r.code(200).send(f)}),t.get("/v1/sessions/:id/tools/:hash",async(s,r)=>{let i=s.params,o=await e.resolveCanonicalId(i.id)??i.id,a=await e.loadToolBlob(o,i.hash);if(a===null){r.code(404).send({error:"tool blob not found"});return}r.header("Content-Type","text/plain; charset=utf-8"),r.code(200).send(a)}),t.get("/v1/sessions/:id/transcript",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=await e.exportBundle(o);if(!a){r.code(404).send({error:"session not found"});return}let d=Kr({record:a.record,history:a.history,promptHistory:a.promptHistory.length>0?a.promptHistory:void 0,hydraVersion:me,machine:ei.hostname(),hydraHost:kf(n)});r.header("Content-Type","text/markdown; charset=utf-8"),r.code(200).send(To(d))}),t.post("/v1/sessions/:id/fork",async(s,r)=>{let i=s.params.id,o=await e.resolveCanonicalId(i)??i,a=s.body??{},d={};if(a.forkAt!==void 0){if(typeof a.forkAt!="string"||a.forkAt.length===0){r.code(400).send({error:"forkAt must be a non-empty string"});return}d.forkAt=a.forkAt}if(a.cwd!==void 0){if(typeof a.cwd!="string"||a.cwd.length===0){r.code(400).send({error:"cwd must be a non-empty string"});return}d.cwd=Ft(a.cwd)}if(a.agentId!==void 0){if(typeof a.agentId!="string"||a.agentId.length===0){r.code(400).send({error:"agentId must be a non-empty string"});return}d.agentId=a.agentId}try{let c=await e.forkSession(o,d);r.code(201).send(c)}catch(c){let l=c;if(l.code===B.SessionNotFound){r.code(404).send({error:l.message});return}if(l.code===B.InvalidParams||l.code===B.AgentNotInstalled){r.code(400).send({error:l.message});return}r.code(500).send({error:l.message})}}),t.post("/v1/sessions/import",async(s,r)=>{let i=s.body??{};if(i.bundle===void 0){r.code(400).send({error:"missing bundle"});return}let o;if(i.cwd!==void 0){if(typeof i.cwd!="string"||i.cwd.length===0){r.code(400).send({error:"cwd must be a non-empty string"});return}o=i.cwd}let a;try{a=Bt(i.bundle)}catch(d){r.code(400).send({error:"invalid bundle",details:d.message});return}try{let d=await e.importBundle(a,{replace:i.replace===!0,...o!==void 0?{cwd:o}:{}});r.code(201).send(d)}catch(d){let c=d;if(c.code===B.BundleAlreadyImported){r.code(409).send({error:"bundle already imported",existingSessionId:c.existingSessionId});return}r.code(500).send({error:c.message})}}),t.get("/v1/sessions/:id/history",async(s,r)=>{let i=s.params.id,o=s.query,a=o?.follow==="1"||o?.follow==="true",d=await e.resolveCanonicalId(i)??i,c=e.get(d),l,f,u=!1,p=[];if(c)a&&(f=c.onBroadcast(h=>{r.raw.writableEnded||(u?r.raw.write(JSON.stringify(h)+`
|
|
247
267
|
`):p.push(h))})),l=await c.getHistorySnapshot();else{let h=await e.getHistory(d);if(h===void 0)return r.code(404).send({error:"session not found"}),r;l=h}r.raw.setHeader("Content-Type","application/x-ndjson"),r.raw.setHeader("Cache-Control","no-cache"),r.raw.statusCode=200;let g=new Set;for(let h of l??[]){r.raw.write(JSON.stringify(h)+`
|
|
248
268
|
`);let w=h;typeof w.recordedAt=="number"&&g.add(String(w.recordedAt))}for(let h of p){let w=h,v=typeof w.recordedAt=="number"?String(w.recordedAt):"";v&&g.has(v)||r.raw.write(JSON.stringify(h)+`
|
|
249
|
-
`)}return u=!0,f?(s.raw.on("close",()=>{f?.(),r.raw.writableEnded||r.raw.end()}),r):(r.raw.end(),r)})}dt();function
|
|
250
|
-
`;await On.mkdir(P.home(),{recursive:!0}),await On.writeFile(Ad(),s,{encoding:"utf8",mode:384})}async function Po(){try{return(await On.readFile(Ad(),"utf8")).trim().length>0}catch(t){if(t.code==="ENOENT")return!1;throw t}}async function Mo(t){if(typeof t!="string"||t.length===0)return!1;let e;try{e=(await On.readFile(Ad(),"utf8")).trim()}catch(c){if(c.code==="ENOENT")return!1;throw c}let n=e.split("$");if(n.length!==6||n[0]!=="scrypt")return!1;let s=parseInt(n[1],10),r=parseInt(n[2],10),i=parseInt(n[3],10);if(!Number.isFinite(s)||!Number.isFinite(r)||!Number.isFinite(i))return!1;let o=Buffer.from(n[4],"hex"),a=Buffer.from(n[5],"hex");if(o.length===0||a.length===0)return!1;let d=await Ff(t,o,a.length,{N:s,r,p:i,maxmem:Of});return d.length!==a.length?!1:Bb(d,a)}var Ub=sr.object({password:sr.string().min(1),label:sr.string().min(1).max(256).optional(),ttlSec:sr.number().int().positive().optional()}),jb=sr.object({id:sr.string().optional()}).optional();function Bf(t,e){t.post("/v1/auth/login",{config:{skipAuth:!0}},async(n,s)=>{let r=qb(n);if(e.rateLimiter.isBlocked(r))return s.code(429).send({error:"Too many failed attempts; try again later."});let i;try{i=Ub.parse(n.body)}catch{return s.code(400).send({error:"Invalid request body"})}if(!await Po())return s.code(403).send({error:"No password configured. Run `hydra-acp auth password` on the daemon host."});if(!await Mo(i.password))return e.rateLimiter.recordFailure(r),s.code(401).send({error:"Invalid password"});e.rateLimiter.recordSuccess(r);let a=await e.store.issue({label:i.label,ttlSec:i.ttlSec});return s.code(200).send({session_token:a.token,id:a.id,expires_at:a.expiresAt})}),t.post("/v1/auth/logout",async(n,s)=>{let r;try{r=jb.parse(n.body??void 0)}catch{return s.code(400).send({error:"Invalid request body"})}let i=r?.id??n.authIdentity;if(!i||i==="service")return s.code(200).send({revoked:!1});let o=await e.store.revoke(i);return s.code(200).send({revoked:o})}),t.get("/v1/auth/verify",async(n,s)=>s.code(200).send({ok:!0})),t.get("/v1/auth/sessions",async(n,s)=>s.code(200).send({sessions:e.store.list()})),t.delete("/v1/auth/sessions/:id",async(n,s)=>{let r=n.params.id;return await e.store.revoke(r)?s.code(204).send():s.code(404).send({error:"Not found"})})}function qb(t){return t.ip||"unknown"}Nr();$o();Xi();dt();import{nanoid as Pd}from"nanoid";Lt();import{randomBytes as Df}from"crypto";function Hf(t,e){t.get("/acp",{websocket:!0},async(n,s)=>{let r=cf({headers:s.headers,url:s.url});if(!r||!await e.validator.validate(r)){n.close(4401,"Unauthorized");return}let i=e.processRegistry?.resolve(r),o=rr(n),a=new Kt(o),d={clientId:`hydra_client_${Pd(12)}`,processIdentity:i,attached:new Map};a.onClose(()=>{for(let f of d.attached.values())e.manager.get(f.sessionId)?.detach(f.clientId);d.attached.clear()});let c=(f,u)=>{if(d.attached.get(f)?.readonly){let g=new Error(`${u} not permitted on a read-only attachment`);throw g.code=B.PermissionDenied,g}};if(a.onRequest("initialize",async f=>{let u=zl.parse(f??{});u.clientInfo?.name&&(d.clientInfo={name:u.clientInfo.name,...u.clientInfo.version!==void 0?{version:u.clientInfo.version}:{}});let p=u.clientInfo?.version;return p&&i&&(i.kind==="extension"?e.onExtensionVersion?.(i.name,p):e.onTransformerVersion?.(i.name,p)),Kb()}),i&&e.extensionCommands){let f=e.extensionCommands;a.onRequest("hydra-acp/commands/register",async u=>{let p=u??{},g=Array.isArray(p.commands)?p.commands.map(h=>{if(!h||typeof h!="object")return;let w=h;if(typeof w.verb!="string")return;let v={verb:w.verb};return typeof w.argsHint=="string"&&(v.argsHint=w.argsHint),typeof w.description=="string"&&(v.description=w.description),v}).filter(h=>h!==void 0):[];return f.register(i.name,a,g),{ok:!0,registered:g.length}}),a.onClose(()=>{f.clear(i.name)})}if(i&&e.extensionMcp){let f=e.extensionMcp;a.onRequest("hydra-acp/mcp_tools/register",async u=>{let p=u??{},g=typeof p.instructions=="string"?p.instructions:void 0,h=Array.isArray(p.tools)?p.tools.map(w=>{if(!w||typeof w!="object")return;let v=w;if(typeof v.name!="string"||v.name.length===0||typeof v.description!="string"||v.inputSchema===null||typeof v.inputSchema!="object")return;let b={name:v.name,description:v.description,inputSchema:v.inputSchema};return v.outputSchema!==null&&typeof v.outputSchema=="object"&&(b.outputSchema=v.outputSchema),b}).filter(w=>w!==void 0):[];if(h.length===0)throw new Error("register_mcp_tools requires at least one tool");return f.register(i.name,a,g,h),{ok:!0,registered:h.length}}),a.onClose(()=>{f.clear(i.name)})}i?.kind==="transformer"&&(a.onRequest("hydra-acp/transformer/initialize",async f=>{let u=f??{},p=Array.isArray(u.intercepts)?u.intercepts.filter(g=>typeof g=="string"):[];if(e.transformers&&(e.transformers.registerConnection(i.name,a,p),e.manager?.defaultTransformers.includes(i.name))){let g=e.transformers.resolveChain([i.name])[0];if(g)for(let h of e.manager.liveSessions())h.addTransformer(g)}return{ack:!0}}),a.onClose(()=>{e.transformers?.deregisterConnection(i.name)}),a.onRequest("hydra-acp/message/emit",async f=>{let u=f??{},p=typeof u.sessionId=="string"?u.sessionId:void 0,g=typeof u.method=="string"?u.method:void 0,h=u.envelope,w=u.route;if(!p||!g)throw Object.assign(new Error("emit_message requires sessionId and method"),{code:-32602});let v=e.manager.get(p);if(!v)throw Object.assign(new Error(`session ${p} not found`),{code:B.SessionNotFound});let b=typeof u.respondsTo=="string"?u.respondsTo:void 0;if(b)return v.dischargeClaim(b,h),{ok:!0};if(w==="chain")return{ok:!0,response:await v.emitToChain(i.name,g,h)};if(w==="daemon")return{ok:!0,response:await v.emitToChain(i.name,g,h)};throw Object.assign(new Error(`unsupported route: ${JSON.stringify(w)}`),{code:-32602})}),a.onRequest("hydra-acp/session/request_permission",async f=>{let u=f??{},p=typeof u.sessionId=="string"?u.sessionId:void 0;if(!p)throw Object.assign(new Error("hydra-acp/session/request_permission requires sessionId"),{code:-32602});let g=e.manager.get(p);if(!g)throw Object.assign(new Error(`session ${p} not found`),{code:B.SessionNotFound});return g.requestPermissionFromClients(u)}),a.onRequest("hydra-acp/transformer/attach",async f=>zb(f,i.name,e)),a.onRequest("hydra-acp/child_session/spawn",async f=>{let u=f??{},p=typeof u.agentId=="string"?u.agentId:e.defaultAgent,g=typeof u.cwd=="string"?u.cwd:void 0,h=typeof u.parentSessionId=="string"?u.parentSessionId:void 0,w=u._meta&&typeof u._meta=="object"?u._meta:void 0,v=w&&w["hydra-acp"]&&typeof w["hydra-acp"]=="object"?w["hydra-acp"]:void 0,b=v&&typeof v.title=="string"?v.title:void 0;if(!g&&h){let O=e.manager.get(h);O&&(g=O.cwd)}if(!g)throw Object.assign(new Error("child_session/spawn requires cwd (or a parentSessionId pointing at a live session whose cwd we can inherit)"),{code:-32602});let x=typeof u.interactive=="boolean"?u.interactive:!1;return{childSessionId:(await e.manager.create({agentId:p,cwd:g,parentSessionId:h,interactive:x,transformChain:[],title:b})).sessionId}}),a.onRequest("hydra-acp/session/fork",async f=>{let u=f??{};if(typeof u.sessionId!="string")throw Object.assign(new Error("fork_session requires sessionId"),{code:B.InvalidParams});let p=typeof u.forkAt=="string"?u.forkAt:void 0,g=typeof u.cwd=="string"?u.cwd:void 0,h=typeof u.agentId=="string"?u.agentId:void 0;return await e.manager.forkSession(u.sessionId,{...p!==void 0?{forkAt:p}:{},...g!==void 0?{cwd:g}:{},...h!==void 0?{agentId:h}:{}})}),a.onRequest("hydra-acp/session/delete",async f=>{let u=f??{};if(typeof u.sessionId!="string")throw Object.assign(new Error("hydra-acp/session/delete requires sessionId"),{code:B.InvalidParams});let p=await e.manager.resolveCanonicalId(u.sessionId)??u.sessionId,g=e.manager.get(p);if(g)return await g.close({deleteRecord:!0}),{deleted:!0,sessionId:p};if(!await e.manager.deleteRecord(p))throw Object.assign(new Error(`session ${p} not found`),{code:B.SessionNotFound});return{deleted:!0,sessionId:p}}),a.onRequest("hydra-acp/child_session/await",async f=>{let u=f??{},p=typeof u.childSessionId=="string"?u.childSessionId:void 0,g=u.until==="idle"?"idle":"turn_complete",h=typeof u.timeoutMs=="number"?Math.min(u.timeoutMs,30*6e4):5*6e4;if(!p)throw Object.assign(new Error("await_child requires childSessionId"),{code:-32602});let w=e.manager.get(p);if(!w)throw Object.assign(new Error(`child session ${p} not found`),{code:B.SessionNotFound});return new Promise(v=>{let b=[],x,C=()=>{clearTimeout(O),x?.(),v({entries:b})};x=w.onBroadcast(q=>{b.push(q),g==="turn_complete"&&q.params?.update?.sessionUpdate==="turn_complete"&&C()});let O=setTimeout(C,h);typeof O.unref=="function"&&O.unref(),w.onClose(()=>C())})}),a.onRequest("hydra-acp/child_session/close",async f=>{let u=f??{},p=typeof u.childSessionId=="string"?u.childSessionId:void 0;if(!p)throw Object.assign(new Error("close_child_session requires childSessionId"),{code:-32602});let g=e.manager.get(p);return g&&await g.close({deleteRecord:!1}),{ok:!0}}),a.onRequest("hydra-acp/connection/keep_alive",async f=>{let u=f??{},p=typeof u.token=="string"?u.token:void 0,g=typeof u.sessionId=="string"?u.sessionId:void 0,h=typeof u.estimatedRemainingMs=="number"?u.estimatedRemainingMs:void 0;return p&&g&&e.manager.get(g)?.keepAliveClaim(p,h),{ok:!0}})),a.onRequest("hydra-acp/session/tool_content",async f=>{let u=f??{};if(typeof u.sessionId!="string"||typeof u.hash!="string")throw Object.assign(new Error("hydra-acp/session/tool_content requires sessionId and hash"),{code:B.InvalidParams});let p=await e.manager.resolveCanonicalId(u.sessionId)??u.sessionId,g=await e.manager.loadToolBlob(p,u.hash);if(g===null)throw Object.assign(new Error("tool content not found"),{code:B.SessionNotFound});return{content:g}}),a.onRequest("session/new",async f=>{let u=Jl.parse(f),p=wt(f?._meta),g=Array.isArray(p.transformers)&&p.transformers.every(N=>typeof N=="string")?p.transformers:e.manager.defaultTransformers??[],h=e.transformers?.resolveChain(g)??[],w,v,b=u.mcpServers;if(p.mcpStdin===!0&&e.mcpTokenRegistry!==void 0&&e.getDaemonOrigin!==void 0){w=Df(32).toString("hex"),v=e.mcpTokenRegistry.reserve(w);let F={name:"hydra-acp-stdin",type:"http",url:`${e.getDaemonOrigin()}/mcp/hydra-acp-stdin`,headers:[{name:"Authorization",value:`Bearer ${w}`}]};b=[...u.mcpServers??[],F]}let x=Fo(e);x!==void 0&&(b=[...b??[],...x.descriptors]);let C;try{C=await e.manager.create({cwd:u.cwd,agentId:p.agentId??e.defaultAgent,mcpServers:b,title:p.title,agentArgs:p.agentArgs,model:p.model,onInstallProgress:Nf(a),transformChain:h,originatingClient:d.clientInfo,...p.interactive!==void 0?{interactive:p.interactive}:{}})}catch(N){throw v!==void 0&&v.abandon(N instanceof Error?N:void 0),x!==void 0&&x.abandon(N instanceof Error?N:void 0),N}if(w!==void 0&&v!==void 0&&e.mcpTokenRegistry!==void 0){let N=w,F=e.mcpTokenRegistry;v.complete(C),C.onClose(()=>{F.unbind(N)})}x!==void 0&&x.bindToSession(C);let O=_o(a,C,d),{entries:q}=await C.attach(O,"full");d.attached.set(C.sessionId,{sessionId:C.sessionId,clientId:O.clientId,readonly:!1}),setImmediate(()=>{(async()=>{for(let N of q)await a.notify(N.method,N.params).catch(()=>{})})()});let W=Cd(C),Q=Rd(C);return{sessionId:C.sessionId,...W?{modes:W}:{},...Q?{models:Q}:{},configOptions:C.buildConfigOptions(),_meta:Td(e.manager,C,{clientId:O.clientId})}}),a.onRequest("session/attach",async f=>{let u=Kl.parse(f),p=u.clientInfo?.version;p&&i&&(i.kind==="extension"?e.onExtensionVersion?.(i.name,p):e.onTransformerVersion?.(i.name,p));let g=wt(u._meta),h=g.resume,w=g.readonly===!0;t.log.info(`session/attach sessionId=${u.sessionId} hasResumeHints=${!!h} readonly=${w}`);let v=h?u.sessionId:await e.manager.resolveCanonicalId(u.sessionId)??u.sessionId,b=e.manager.get(v);if(!b&&w){let N=await e.manager.loadFromDisk(v);if(!N){let J=new Error(`session ${u.sessionId} not found`);throw J.code=B.SessionNotFound,J}let F=await e.manager.loadHistory(v),U=u.clientId??`cli_${Pd(8)}`;d.attached.set(N.hydraSessionId,{sessionId:N.hydraSessionId,clientId:U,readonly:!0}),t.log.info(`session/attach OK (viewer) sessionId=${N.hydraSessionId} clientId=${U} attachedCount=${d.attached.size} replayed=${F.length}`);for(let J of F)await a.notify(J.method,J.params).catch(()=>{});return{sessionId:N.hydraSessionId,clientId:U,connectedClients:[U],historyPolicy:"full",replayed:F.length,_meta:Jb(N)}}if(!b){let N=await e.manager.loadFromDisk(v),F=N;if(h&&(F={...N,hydraSessionId:u.sessionId,upstreamSessionId:h.upstreamSessionId,agentId:h.agentId,cwd:h.cwd,...h.title!==void 0?{title:h.title}:{},...h.agentArgs!==void 0?{agentArgs:h.agentArgs}:{}}),!F){let ie=new Error(`session ${u.sessionId} not found and no resume hints provided`);throw ie.code=B.SessionNotFound,ie}let U=F.originatingClient?F:{...F,originatingClient:d.clientInfo},J=Fo(e);try{b=await e.manager.resurrect({...U,mcpServers:J?.descriptors,onInstallProgress:Nf(a)})}catch(ie){throw J!==void 0&&J.abandon(ie instanceof Error?ie:void 0),ie}J!==void 0&&J.bindToSession(b),Ed(b,e)}let x=_o(a,b,d,u.clientInfo,u.clientId),C=g.replayMode==="drip",{entries:O,appliedPolicy:q}=await b.attach(x,u.historyPolicy,{afterMessageId:u.afterMessageId,raw:C,...g.toolContent!==void 0?{toolContent:g.toolContent}:{}});if(d.attached.set(b.sessionId,{sessionId:b.sessionId,clientId:x.clientId,readonly:w}),t.log.info(`session/attach OK sessionId=${b.sessionId} clientId=${x.clientId} attachedCount=${d.attached.size} requestedPolicy=${u.historyPolicy} appliedPolicy=${q} replayed=${O.length} readonly=${w}${C?" replayMode=drip":""}`),C){let N=g.dripSpeed&&g.dripSpeed>0?g.dripSpeed:1,F=750;(async()=>{let U=null;for(let J of O){let ie=typeof J.recordedAt=="number"?J.recordedAt:null;if(U!==null&&ie!==null){let be=Math.min(F,Math.max(0,(ie-U)/N));be>0&&await new Promise(te=>setTimeout(te,be))}ie!==null&&(U=ie);try{await a.notify(J.method,J.params)}catch{return}}})()}else for(let F=0;F<O.length;F++){let U=O[F],J=a.notify(U.method,U.params).catch(()=>{});(F+1)%200===0&&await J}b.replayPendingPermissions(x);let W=Cd(b),Q=Rd(b);return{sessionId:b.sessionId,clientId:x.clientId,connectedClients:b.connectedClients(x.clientId),historyPolicy:q,replayed:O.length,...W?{modes:W}:{},...Q?{models:Q}:{},configOptions:b.buildConfigOptions(),_meta:Td(e.manager,b)}}),a.onRequest("session/detach",async f=>{let u=Vl.parse(f),p=d.attached.get(u.sessionId);if(!p){let h=new Error("client not attached to that session");throw h.code=B.SessionNotFound,h}let g=e.manager.get(u.sessionId);return g?.detach(p.clientId),d.attached.delete(u.sessionId),g&&e.manager.reapIfOrphanedNonInteractive(u.sessionId),{sessionId:u.sessionId,_meta:{[Ct]:{detachStatus:"detached"}}}}),a.onRequest("session/list",async f=>{let u=Yl.parse(f??{});return{sessions:(await e.manager.list({cwd:u.cwd})).filter(w=>w.originatingClient?.name!==ds).map(Gl)}}),a.onRequest("hydra-acp/agents/list",async()=>{if(!e.registry){let f=new Error("agent registry unavailable");throw f.code=B.InternalError,f}return Ws(e.registry)}),a.onRequest("session/prompt",async f=>{let u=Xl.parse(f);c(u.sessionId,"session/prompt");let p=d.attached.get(u.sessionId);if(!p){t.log.warn(`session/prompt rejected: not attached sessionId=${u.sessionId} attachedKeys=[${[...d.attached.keys()].join(",")}]`);let h=new Error("not attached to session");throw h.code=B.SessionNotFound,h}let g=e.manager.get(u.sessionId);if(!g){let h=await e.manager.loadFromDisk(u.sessionId);if(!h){let b=new Error(`session ${u.sessionId} not found`);throw b.code=B.SessionNotFound,b}t.log.info(`session/prompt auto-resurrecting cold sessionId=${u.sessionId}`);let w=Fo(e);try{g=await e.manager.resurrect({...h,mcpServers:w?.descriptors})}catch(b){throw w!==void 0&&w.abandon(b instanceof Error?b:void 0),b}w!==void 0&&w.bindToSession(g),Ed(g,e);let v=_o(a,g,d,void 0,p.clientId);await g.attach(v,"none")}return g.prompt(p.clientId,u)});let l=f=>{let u;try{u=Ji.parse(f)}catch(h){t.log.warn(`session/cancel: invalid params: ${h.message}`);return}let p=d.attached.get(u.sessionId);if(!p)return;if(p.readonly){t.log.warn(`session/cancel dropped (readonly attachment) sessionId=${u.sessionId}`);return}let g=e.manager.get(u.sessionId);g&&g.cancel(p.clientId).catch(h=>{t.log.warn(`session/cancel for ${u.sessionId}: ${h.message}`)})};a.onNotification("session/cancel",l),a.onRequest("session/cancel",async f=>{let u=Ji.parse(f);return c(u.sessionId,"session/cancel"),l(f),null}),a.onRequest("hydra-acp/prompt/cancel",async f=>{let u=eu.parse(f);c(u.sessionId,"hydra-acp/prompt/cancel");let p=e.manager.get(u.sessionId);if(!p){let g=new Error(`session ${u.sessionId} not found`);throw g.code=B.SessionNotFound,g}return p.cancelQueuedPrompt(u.messageId)}),a.onRequest("hydra-acp/session/force_cancel",async f=>{let u=Ji.parse(f);c(u.sessionId,"hydra-acp/session/force_cancel");let p=e.manager.get(u.sessionId);if(!p){let g=new Error(`session ${u.sessionId} not found`);throw g.code=B.SessionNotFound,g}return p.forceCancel()}),a.onRequest("hydra-acp/prompt/update",async f=>{let u=tu.parse(f);c(u.sessionId,"hydra-acp/prompt/update");let p=e.manager.get(u.sessionId);if(!p){let g=new Error(`session ${u.sessionId} not found`);throw g.code=B.SessionNotFound,g}return p.updateQueuedPrompt(u.messageId,u.prompt)}),a.onRequest("hydra-acp/prompt/amend",async f=>{let u=nu.parse(f);c(u.sessionId,"hydra-acp/prompt/amend");let p=d.attached.get(u.sessionId);if(!p){let h=new Error("not attached to session");throw h.code=B.SessionNotFound,h}let g=e.manager.get(u.sessionId);if(!g){let h=new Error(`session ${u.sessionId} not found`);throw h.code=B.SessionNotFound,h}return g.amendPrompt(p.clientId,u)}),a.onRequest("session/load",async f=>{let u=f??{},p=typeof u.sessionId=="string"?u.sessionId:void 0;if(!p){let C=new Error("session/load requires sessionId");throw C.code=B.InvalidParams,C}let g=await e.manager.resolveCanonicalId(p)??p,h=e.manager.get(g);if(!h){let C=await e.manager.loadFromDisk(g);if(!C){let q=new Error(`session ${p} not found in memory or on disk`);throw q.code=B.SessionNotFound,q}let O=Fo(e);try{h=await e.manager.resurrect({...C,mcpServers:O?.descriptors})}catch(q){throw O!==void 0&&O.abandon(q instanceof Error?q:void 0),q}O!==void 0&&O.bindToSession(h),Ed(h,e)}let w=_o(a,h,d),{entries:v}=await h.attach(w,"pending_only");d.attached.set(h.sessionId,{sessionId:h.sessionId,clientId:w.clientId,readonly:!1});for(let C of v)await a.notify(C.method,C.params);h.replayPendingPermissions(w);let b=Cd(h),x=Rd(h);return{sessionId:h.sessionId,...b?{modes:b}:{},...x?{models:x}:{},configOptions:h.buildConfigOptions(),_meta:Td(e.manager,h,{clientId:w.clientId})}}),a.onRequest("session/set_model",async f=>{let u=f?.sessionId;typeof u=="string"&&c(u,"session/set_model");let p=Wb(f,e.manager);if(p.kind==="error"){t.log.warn(p.logMessage);let w=new Error(p.message);throw w.code=p.code,w}if(p.kind==="no_op")return t.log.warn(p.logMessage),await a.notify("session/update",{sessionId:p.sessionId,update:{sessionUpdate:"current_model_update",currentModel:p.currentModel}}).catch(()=>{}),null;t.log.info(p.logMessage);let{modelId:g}=p,h=await p.session.forwardRequest("session/set_model",{...f,modelId:g});return p.session.applyModelChange(g),h}),a.onRequest("session/set_mode",async f=>{let u=f,p=u?.sessionId;if(typeof p=="string"&&c(p,"session/set_mode"),!u||typeof u.sessionId!="string"){let w=new Error("session/set_mode requires string sessionId");throw w.code=B.InvalidParams,w}if(typeof u.modeId!="string"){let w=new Error("session/set_mode requires string modeId");throw w.code=B.InvalidParams,w}let g=e.manager.get(u.sessionId);if(!g){let w=new Error(`session ${u.sessionId} not found`);throw w.code=B.SessionNotFound,w}let h=await g.forwardRequest("session/set_mode",f);return g.applyModeChange(u.modeId),h}),a.onRequest("session/set_config_option",async f=>{let u=f,p=v=>{let b=new Error(v);return b.code=B.InvalidParams,b},g=u?.sessionId;if(typeof g=="string"&&c(g,"session/set_config_option"),!u||typeof u.sessionId!="string")throw p("session/set_config_option requires string sessionId");if(typeof u.configId!="string")throw p("session/set_config_option requires string configId");if(typeof u.value!="string")throw p("session/set_config_option requires string value");let h=e.manager.get(u.sessionId);if(!h){let v=new Error(`session ${u.sessionId} not found`);throw v.code=B.SessionNotFound,v}let w=h.buildConfigOptions().find(v=>v.id===u.configId);if(!w)throw p(`unknown configId ${JSON.stringify(u.configId)} for this session`);if(!w.options.some(v=>v.value===u.value))throw p(`value ${JSON.stringify(u.value)} is not valid for configId ${JSON.stringify(u.configId)}`);switch(u.configId){case"model":{u.value!==h.currentModel&&await h.forwardRequest("session/set_model",{sessionId:u.sessionId,modelId:u.value}),h.applyModelChange(u.value);break}case"mode":{u.value!==h.currentMode&&await h.forwardRequest("session/set_mode",{sessionId:u.sessionId,modeId:u.value}),h.applyModeChange(u.value);break}case"agent":{u.value!==h.agentId&&await h.setAgent(u.value);break}default:throw p(`configId ${JSON.stringify(u.configId)} is not settable`)}return{configOptions:h.buildConfigOptions()}}),a.setDefaultHandler(async(f,u)=>{if(!u.startsWith("session/")||f===null||typeof f!="object"){let h=new Error(`Method not found: ${u}`);throw h.code=B.MethodNotFound,h}let p=f.sessionId;if(typeof p!="string"){let h=new Error(`Method not found: ${u}`);throw h.code=B.MethodNotFound,h}c(p,u);let g=e.manager.get(p);if(!g){let h=new Error(`session ${p} not found`);throw h.code=B.SessionNotFound,h}return g.forwardRequest(u,f)})})}function Nf(t){return e=>{let n={agentId:e.agentId,version:e.version,source:e.source,phase:e.phase};"receivedBytes"in e&&(n.receivedBytes=e.receivedBytes),"totalBytes"in e&&(n.totalBytes=e.totalBytes),"packageSpec"in e&&(n.packageSpec=e.packageSpec),t.notify(Ki,n).catch(()=>{})}}function Cd(t){let e=t.availableModes();if(e.length===0)return;let n=e.map(r=>{let i={id:r.id,name:r.name??r.id};return r.description!==void 0&&(i.description=r.description),i});return{currentModeId:t.currentMode??e[0].id,availableModes:n}}function Rd(t){let e=t.availableModels();if(e.length===0)return;let n=e.map(r=>{let i={modelId:r.modelId};return r.name!==void 0&&(i.name=r.name),r.description!==void 0&&(i.description=r.description),i});return{currentModelId:t.currentModel??e[0].modelId,availableModels:n}}function Wb(t,e){if(!t||typeof t!="object")return{kind:"error",code:B.InvalidParams,message:"session/set_model requires params",logMessage:"session/set_model rejected: params not an object"};let n=t;if(typeof n.sessionId!="string")return{kind:"error",code:B.InvalidParams,message:"session/set_model requires string sessionId",logMessage:"session/set_model rejected: missing/non-string sessionId"};if(typeof n.modelId!="string")return{kind:"error",code:B.InvalidParams,message:"session/set_model requires string modelId",logMessage:`session/set_model rejected: missing/non-string modelId sessionId=${n.sessionId}`};let s=e.get(n.sessionId);if(!s)return{kind:"error",code:B.SessionNotFound,message:`session ${n.sessionId} not found`,logMessage:`session/set_model rejected: session not found sessionId=${n.sessionId}`};let r=s.availableModels(),i=Js(n.modelId,r);if(i.kind==="none")return{kind:"ok",session:s,modelId:n.modelId,logMessage:`session/set_model passthrough (no availableModels) sessionId=${n.sessionId} modelId=${JSON.stringify(n.modelId)}`};if(i.kind==="exact")return{kind:"ok",session:s,modelId:n.modelId,logMessage:`session/set_model accepted sessionId=${n.sessionId} modelId=${JSON.stringify(n.modelId)}`};if(i.kind==="resolved")return{kind:"ok",session:s,modelId:i.modelId,logMessage:`session/set_model resolved sessionId=${n.sessionId} requested=${JSON.stringify(n.modelId)} \u2192 ${JSON.stringify(i.modelId)}`};let o=r.map(d=>d.modelId).join(", "),a=i.kind==="ambiguous"?`ambiguous (trailing-segment matches [${i.candidates.join(", ")}])`:"not in availableModels";return s.currentModel!==void 0&&s.currentModel.length>0?{kind:"no_op",session:s,sessionId:n.sessionId,currentModel:s.currentModel,logMessage:`session/set_model no_op (resyncing client) sessionId=${n.sessionId} requested=${JSON.stringify(n.modelId)} ${a} actual=${JSON.stringify(s.currentModel)} agentId=${s.agentId} known=[${o}]`}:{kind:"error",code:B.InvalidParams,message:`model "${n.modelId}" is ${a==="not in availableModels"?"not in this session's availableModels":a} (agent ${s.agentId}); known models: ${o}`,logMessage:`session/set_model rejected sessionId=${n.sessionId} modelId=${JSON.stringify(n.modelId)} ${a} agentId=${s.agentId} known=[${o}] (no current model to fall back to)`}}async function zb(t,e,n){let s=t??{},r=typeof s.sessionId=="string"?s.sessionId:void 0;if(!r)throw Object.assign(new Error("transformer/attach requires sessionId"),{code:B.InvalidParams});if(!n.transformers)throw Object.assign(new Error("transformer manager not configured"),{code:B.InternalError});let i=n.transformers.resolveChain([e])[0];if(!i)throw Object.assign(new Error(`transformer ${e} is not connected (call hydra-acp/transformer/initialize first)`),{code:B.InternalError});let o=n.manager.get(r);if(!o)throw Object.assign(new Error(`session ${r} not found`),{code:B.SessionNotFound});return o.addTransformer(i),{ok:!0}}function Jb(t){let e={sessionId:t.hydraSessionId,upstreamSessionId:t.upstreamSessionId,cwd:t.cwd,title:t.title,agentId:t.agentId,currentModel:t.currentModel,currentUsage:t.currentUsage,forkedFromSessionId:t.forkedFromSessionId,forkedFromMessageId:t.forkedFromMessageId,originatingClient:t.originatingClient,interactive:t.interactive,updatedAt:t.createdAt??new Date().toISOString(),attachedClients:0,status:"cold",busy:!1,awaitingInput:!1},n={currentMode:t.currentMode,agentArgs:t.agentArgs,availableCommands:t.agentCommands,availableModes:t.agentModes,availableModels:t.agentModels};return{[Ct]:zi(e,n)}}function Td(t,e,n={}){let s=t.liveListEntry(e),r={clientId:n.clientId,currentMode:e.currentMode,agentArgs:e.agentArgs,availableCommands:e.mergedAvailableCommands(),availableModes:e.availableModes(),availableModels:e.availableModels(),turnStartedAt:e.turnStartedAt,agentCapabilities:e.agentCapabilities,queue:e.queueSnapshot()};return Wi(e.agentMeta,zi(s,r))}function Kb(){return{protocolVersion:yt,agentInfo:{name:"hydra",version:me},agentCapabilities:{promptCapabilities:{image:!0,audio:!0,embeddedContext:!0},mcpCapabilities:{http:!0,sse:!0},loadSession:!0,sessionCapabilities:{attach:{},list:{}}},authMethods:[{id:"bearer-token",description:"Bearer token presented at WS upgrade"}],_meta:Wi(void 0,{prompt:{queueing:!0,cancelling:!0,updating:!0,amending:!0,pipelining:!1},agents:{list:!0,installProgress:!0}})}}function Ed(t,e){if(!(!e.transformers||!e.manager))for(let n of e.manager.defaultTransformers){let s=e.transformers.resolveChain([n])[0];s&&t.addTransformer(s)}}function _o(t,e,n,s,r){return{clientId:r??`cli_${Pd(8)}`,connection:t,clientInfo:s}}function Fo(t){if(t.extensionMcp===void 0||t.mcpTokenRegistry===void 0||t.getDaemonOrigin===void 0)return;let e=t.extensionMcp.list();if(e.length===0)return;let n=Df(32).toString("hex"),s=t.mcpTokenRegistry.reserve(n),r=t.getDaemonOrigin(),i=e.map(a=>({name:a,type:"http",url:`${r}/mcp/${a}`,headers:[{name:"Authorization",value:`Bearer ${n}`}]})),o=t.mcpTokenRegistry;return{descriptors:i,bindToSession:a=>{s.complete(a),a.onClose(()=>{o.unbind(n)})},abandon:a=>s.abandon(a)}}var Oo=class{byToken=new Map;reserve(e){if(this.byToken.has(e))throw new Error("mcp token already bound");let n,s,r=new Promise((o,a)=>{n=o,s=a});r.catch(()=>{});let i={session:void 0,sessionReady:r,disposers:[]};return this.byToken.set(e,i),{complete:o=>{i.session=o,n(o)},abandon:o=>{this.byToken.delete(e),s(o??new Error("mcp token reservation abandoned"))}}}bind(e,n){let{complete:s}=this.reserve(e);s(n)}lookup(e){return this.byToken.get(e)}addDisposer(e,n){let s=this.byToken.get(e);s!==void 0&&s.disposers.push(n)}async unbind(e){let n=this.byToken.get(e);if(n!==void 0){this.byToken.delete(e);for(let s of n.disposers)try{await s()}catch{}}}size(){return this.byToken.size}};import{randomUUID as Vb}from"crypto";import{McpServer as Yb}from"@modelcontextprotocol/sdk/server/mcp.js";import{StreamableHTTPServerTransport as Qb}from"@modelcontextprotocol/sdk/server/streamableHttp.js";import{z as tt}from"zod";var Uf="Bearer ";function Lo(t){let e=t.headers.authorization;if(typeof e!="string"||!e.startsWith(Uf))return;let n=e.slice(Uf.length).trim();return n.length>0?n:void 0}function Gb(t){let e=new Yb({name:"hydra-acp-stdin",version:"1.0.0"},{instructions:"Piped input from `hydra cat --stream` is exposed here as a byte stream. Use `tail` for the latest N bytes (good for finding the end of a log), `head` for the first N bytes (good for headers/preamble), `read` for windowed reads against an absolute byte cursor, `wait_for_more` to block until new bytes arrive past a cursor, and `info` for the current cursors/capacity/closed status. Byte payloads come back base64-encoded."});return e.registerTool("tail",{description:"Return the most recent `bytes` bytes of piped stdin (capped server-side, default 64 KiB max). `truncated:true` means older bytes existed but have been evicted from the ring.",inputSchema:{bytes:tt.number().int().min(1).describe("How many trailing bytes to return.")}},async({bytes:n})=>{let s=t.streamTail(n);return{content:[{type:"text",text:JSON.stringify(s)}],structuredContent:s}}),e.registerTool("head",{description:"Return the first `bytes` bytes of piped stdin (capped server-side, default 64 KiB max). `truncated:true` means the head has already been evicted from the ring and the returned bytes start at the oldest still-resident cursor.",inputSchema:{bytes:tt.number().int().min(1).describe("How many leading bytes to return.")}},async({bytes:n})=>{let s=t.streamHead(n);return{content:[{type:"text",text:JSON.stringify(s)}],structuredContent:s}}),e.registerTool("read",{description:"Read up to `max_bytes` bytes starting at absolute byte `cursor`. Returns `{bytes, nextCursor, gap?, eof?}` \u2014 `gap` is the number of bytes silently skipped because the ring had evicted them; `eof:true` means the producer closed and there is nothing left to read.",inputSchema:{cursor:tt.number().int().min(0).describe("Absolute byte offset to start reading from. Use 0 to read from the very beginning (may produce a gap if old bytes have been evicted)."),max_bytes:tt.number().int().min(1).optional().describe("Optional cap on how many bytes to return. Server caps at 64 KiB regardless."),wait_ms:tt.number().int().min(0).optional().describe("If no bytes are available, block up to this many ms for more (capped server-side at 60_000).")}},async({cursor:n,max_bytes:s,wait_ms:r})=>{let i=await t.streamRead(n,s,r);return{content:[{type:"text",text:JSON.stringify(i)}],structuredContent:i}}),e.registerTool("wait_for_more",{description:"Block until bytes are available past `cursor`, the stream closes, or `timeout_ms` elapses. Returns one of {data, eof, timeout} plus the current `writeCursor`. Use this when you've consumed everything up to a cursor and want to wait for more without busy-polling.",inputSchema:{cursor:tt.number().int().min(0).describe("The cursor you've already consumed up to."),timeout_ms:tt.number().int().min(0).describe("Maximum ms to block (server caps at 60_000).")}},async({cursor:n,timeout_ms:s})=>{let r=await t.streamWaitFor(n,s),i=t.streamInfo(),o={outcome:r,writeCursor:i.writeCursor,closed:i.closed};return{content:[{type:"text",text:JSON.stringify(o)}],structuredContent:o}}),e.registerTool("grep",{description:"Scan piped stdin line-by-line and return lines matching `pattern`. Prefer this over `read` when the question is 'find lines that mention X' \u2014 it filters server-side so you don't pull and decode 64 KiB base64 windows. Returns `{matches: [{cursor, line, before?, after?}], truncated, nextCursor, gap?, scannedBytes, eof?}`. Lines come back as decoded UTF-8 strings (not base64). When `truncated:true`, re-call with `cursor: nextCursor` to resume.",inputSchema:{pattern:tt.string().min(1).describe("Search pattern. Treated as a JavaScript regular expression by default (set `regex:false` for a literal substring match)."),regex:tt.boolean().optional().describe("Default true. Pass false to treat `pattern` as a literal substring."),case_insensitive:tt.boolean().optional().describe("Default false. Pass true for case-insensitive matching."),invert:tt.boolean().optional().describe("Default false. Pass true to return lines that do NOT match the pattern."),max_matches:tt.number().int().min(1).optional().describe("Default 100. Capped server-side at 1000."),max_bytes:tt.number().int().min(1).optional().describe("Default 64 KiB output. Capped server-side at 256 KiB."),context_before:tt.number().int().min(0).optional().describe("Default 0. Number of lines before each match to include (capped at 20)."),context_after:tt.number().int().min(0).optional().describe("Default 0. Number of lines after each match to include (capped at 20)."),cursor:tt.number().int().min(0).optional().describe("Optional absolute byte offset to start scanning from. Omit to scan from the oldest still-resident byte. Pass the `nextCursor` from a previous truncated call to resume.")}},async n=>{let s={pattern:n.pattern};n.regex!==void 0&&(s.regex=n.regex),n.case_insensitive!==void 0&&(s.caseInsensitive=n.case_insensitive),n.invert!==void 0&&(s.invert=n.invert),n.max_matches!==void 0&&(s.maxMatches=n.max_matches),n.max_bytes!==void 0&&(s.maxBytes=n.max_bytes),n.context_before!==void 0&&(s.contextBefore=n.context_before),n.context_after!==void 0&&(s.contextAfter=n.context_after),n.cursor!==void 0&&(s.cursor=n.cursor);let r=t.streamGrep(s),i=r;return{content:[{type:"text",text:JSON.stringify(r)}],structuredContent:i}}),e.registerTool("info",{description:"Report cursor / capacity / closed state of the stdin ring. Cheap; safe to call repeatedly.",inputSchema:{}},async()=>{let n=t.streamInfo();return{content:[{type:"text",text:JSON.stringify(n)}],structuredContent:n}}),e}var Xb=1e4;function jf(t,e){let n=new Map;async function s(o,a){let d=n.get(o);if(d!==void 0)return d.transport;let c=Gb(a),l=new Qb({sessionIdGenerator:()=>Vb()});await c.connect(l);let f={server:c,transport:l};return n.set(o,f),e.addDisposer(o,async()=>{n.delete(o);try{await l.close()}catch{}try{await c.close()}catch{}}),l}async function r(o,a){let d=Lo(o);if(d===void 0){a.code(401).send({error:"missing bearer token"});return}let c=e.lookup(d);if(c===void 0){a.code(404).send({error:"unknown stdin token"});return}let l;if(c.session!==void 0)l=c.session;else{let u,p=new Promise(h=>{u=setTimeout(()=>h(void 0),Xb)}),g=await Promise.race([c.sessionReady.catch(()=>{}),p]);if(u!==void 0&&clearTimeout(u),g===void 0){a.code(503).send({error:"session not ready"});return}l=g}let f=await s(d,l);a.hijack(),await f.handleRequest(o.raw,a.raw,o.body)}let i={config:{skipAuth:!0}};t.post("/mcp/hydra-acp-stdin",i,async(o,a)=>{await r(o,a)}),t.get("/mcp/hydra-acp-stdin",i,async(o,a)=>{await r(o,a)}),t.delete("/mcp/hydra-acp-stdin",i,async(o,a)=>{await r(o,a)})}var Bo=class{byName=new Map;changeHandlers=[];register(e,n,s,r){this.byName.set(e,{connection:n,instructions:s,tools:[...r]}),this.fireChanged(e,"register")}clear(e){this.byName.delete(e)&&this.fireChanged(e,"clear")}lookup(e){return this.byName.get(e)}list(){return Array.from(this.byName.keys())}onChange(e){return this.changeHandlers.push(e),()=>{let n=this.changeHandlers.indexOf(e);n>=0&&this.changeHandlers.splice(n,1)}}fireChanged(e,n){for(let s of this.changeHandlers)try{s(e,n)}catch{}}};import{StreamableHTTPServerTransport as iv}from"@modelcontextprotocol/sdk/server/streamableHttp.js";import{randomUUID as ov}from"crypto";import{Server as Zb}from"@modelcontextprotocol/sdk/server/index.js";import{CallToolRequestSchema as ev,ListToolsRequestSchema as tv}from"@modelcontextprotocol/sdk/types.js";var nv=6e4;function qf(t,e,n,s={}){let r=s.invokeTimeoutMs??nv,i=typeof n=="function"?async()=>n():async()=>n,o=new Zb({name:t,version:"1.0.0"},{capabilities:{tools:{listChanged:!1}},...e.instructions!==void 0?{instructions:e.instructions}:{}}),a=new Map(e.tools.map(d=>[d.name,d]));return o.setRequestHandler(tv,async()=>({tools:e.tools.map(d=>({name:d.name,description:d.description,inputSchema:d.inputSchema,...d.outputSchema!==void 0?{outputSchema:d.outputSchema}:{}}))})),o.setRequestHandler(ev,async d=>{let c=d.params.name;if(!a.has(c))return No(`unknown tool: ${c}`);try{let l=await i(),f=await sv(e.connection,t,c,d.params.arguments??{},l,r);return rv(f,c)}catch(l){return No(l instanceof Error?l.message:String(l))}}),o}async function sv(t,e,n,s,r,i){let o,a=new Promise((d,c)=>{o=setTimeout(()=>c(new Error(`extension timeout after ${i}ms`)),i)});try{return await Promise.race([t.request("hydra-acp/mcp_tools/invoke",{server:e,tool:n,args:s,sessionId:r}),a])}finally{o!==void 0&&clearTimeout(o)}}function rv(t,e){if(t===null||typeof t!="object")return No(`extension ${e} returned non-object`);let n=t;return Array.isArray(n.content)?n:No(`extension ${e} omitted content array`)}function No(t){return{content:[{type:"text",text:t}],isError:!0}}var av=1e4;function Wf(t,e,n,s={}){let r=new Map;async function i(l){try{await l.transport.close()}catch{}try{await l.server.close()}catch{}}function o(l){for(let f of r.values()){let u=f.get(l);u!==void 0&&(f.delete(l),i(u))}}n.onChange(l=>{o(l)});async function a(l,f){let u=r.get(l);u===void 0&&(u=new Map,r.set(l,u),e.addDisposer(l,async()=>{let b=r.get(l);if(b!==void 0){r.delete(l);for(let x of b.values())await i(x)}}));let p=u.get(f);if(p!==void 0)return p.transport;let g=n.lookup(f);if(g===void 0)return;let w=qf(f,g,async()=>{let b=e.lookup(l);if(b===void 0)throw new Error("mcp token no longer bound");if(b.session!==void 0)return b.session.sessionId;let x,C=new Promise(q=>{x=setTimeout(()=>q(void 0),av)}),O=await Promise.race([b.sessionReady.catch(()=>{}),C]);if(x!==void 0&&clearTimeout(x),O===void 0)throw new Error("session not ready");return O.sessionId},s.buildOptions),v=new iv({sessionIdGenerator:()=>ov()});return await w.connect(v),u.set(f,{server:w,transport:v}),v}async function d(l,f){let u=Lo(l);if(u===void 0){f.code(401).send({error:"missing bearer token"});return}if(e.lookup(u)===void 0){f.code(404).send({error:"unknown mcp token"});return}let g=l.params.name,h=await a(u,g);if(h===void 0){f.code(404).send({error:`unknown mcp server: ${g}`});return}f.hijack(),await h.handleRequest(l.raw,f.raw,l.body)}let c={config:{skipAuth:!0}};t.post("/mcp/:name",c,async(l,f)=>{await d(l,f)}),t.get("/mcp/:name",c,async(l,f)=>{await d(l,f)}),t.delete("/mcp/:name",c,async(l,f)=>{await d(l,f)})}async function Kf(t,e){fv(t);let n=t.daemon.tls?{key:await Ln.readFile(t.daemon.tls.key),cert:await Ln.readFile(t.daemon.tls.cert)}:void 0;await Ln.mkdir(P.home(),{recursive:!0});let{stream:s,fileStream:r}=await uv(t.daemon.logLevel),i=dv({logger:{level:t.daemon.logLevel,stream:s},https:n??null,bodyLimit:256*1024*1024});await i.register(cv,{options:{handleProtocols:Cl}}),Ua(Y=>{i.log.info(Y)}),Wa(Y=>{i.log.info(Y)});let o=await bo.load(),a=new xo,d=new ko,c=new So([new vo(e),new Io(o),d]),l=df({validator:c});i.addHook("onRequest",async(Y,xe)=>{Y.routeOptions.config?.skipAuth||Y.url==="/acp"||Y.url?.startsWith("/acp?")||await l(Y,xe)});let f=setInterval(()=>{o.sweepExpired()},300*1e3);f.unref();let u=new ji(t,{onFetched:()=>{Xu(u,w)}});vd(Y=>i.log.info(Y));let p={info:Y=>i.log.info(Y),warn:Y=>i.log.warn(Y)},g=Y=>_n.spawn({...Y,stderrTailBytes:t.daemon.agentStderrTailBytes,logger:p});Pl(t.compressToolContent);let h=new go,w=new lo(u,g,void 0,{idleTimeoutMs:t.daemon.sessionIdleTimeoutSeconds*1e3,defaultModels:t.defaultModels,synopsisAgent:t.synopsisAgent,synopsisModel:t.synopsisModel,synopsisOnClose:t.synopsisOnClose,defaultTransformers:t.defaultTransformers,sessionHistoryMaxEntries:t.daemon.sessionHistoryMaxEntries,logger:p,npmRegistry:t.npmRegistry,extensionCommands:h,defaultCwd:t.defaultCwd}),v=new mo(dl(t),void 0,{tokenRegistry:d}),b=new ho(cl(t),void 0,{tokenRegistry:d});Cf(i,me,er(t)),xf(i,w,{agentId:t.defaultAgent,cwd:t.defaultCwd,publicHost:t.daemon.publicHost,host:t.daemon.host,port:t.daemon.port}),Af(i,u,w,{npmRegistry:t.npmRegistry}),Rf(i,v),Tf(i,b),Ef(i,{defaultAgent:t.defaultAgent,defaultCwd:t.defaultCwd,defaultModels:{...t.defaultModels},...t.synopsisAgent!==void 0?{synopsisAgent:t.synopsisAgent}:{},...t.synopsisModel!==void 0?{synopsisModel:t.synopsisModel}:{},synopsisOnClose:t.synopsisOnClose,defaultTransformers:[...t.defaultTransformers]}),Bf(i,{store:o,rateLimiter:a});let x=new Oo,C=new Bo;jf(i,x),Wf(i,x,C);let O,q=()=>{if(O!==void 0)return O;let Y=i.server.address(),xe=Y&&typeof Y=="object"?Y.port:t.daemon.port;return O=`${t.daemon.tls?"https":"http"}://${t.daemon.host}:${xe}`,O};Hf(i,{validator:c,manager:w,defaultAgent:t.defaultAgent,processRegistry:d,onExtensionVersion:(Y,xe)=>v.reportVersion(Y,xe),onTransformerVersion:(Y,xe)=>b.reportVersion(Y,xe),transformers:b,extensionCommands:h,mcpTokenRegistry:x,extensionMcp:C,getDaemonOrigin:q,registry:u}),await i.listen({host:t.daemon.host,port:t.daemon.port});let W=i.server.address(),Q=W&&typeof W=="object"?W.port:t.daemon.port;await Ln.mkdir(P.home(),{recursive:!0}),await Ln.writeFile(P.pidFile(),JSON.stringify({pid:process.pid,host:t.daemon.host,port:Q,startedAt:new Date().toISOString()})+`
|
|
251
|
-
`,{encoding:"utf8",mode:384});let N=t.daemon.tls?"https":"http",F=t.daemon.tls?"wss":"ws",U={daemonUrl:`${N}://${t.daemon.host}:${Q}`,daemonHost:t.daemon.host,daemonPort:Q,serviceToken:e,daemonWsUrl:`${F}://${t.daemon.host}:${Q}/acp`,hydraHome:P.home()};v.setContext(U),b.setContext(U),await v.start(),await b.start(),w.resurrectPendingQueues().catch(Y=>{i.log.warn(`queue replay scan failed: ${Y.message}`)});let J=t.daemon.agentSyncIntervalMinutes*60*1e3,ie=J>0?
|
|
252
|
-
`),process.exit(1);return}throw d}let i=await
|
|
253
|
-
`);let o=!1,a=
|
|
269
|
+
`)}return u=!0,f?(s.raw.on("close",()=>{f?.(),r.raw.writableEnded||r.raw.end()}),r):(r.raw.end(),r)})}dt();function Cf(t,e,n,s={}){t.get("/v1/agents",async()=>zs(e)),t.get("/v1/registry",async()=>e.load()),t.post("/v1/registry/refresh",async()=>{let r=await e.refresh();return{version:r.version,agentCount:r.agents.length}}),t.post("/v1/agents/:id/install",async(r,i)=>{let o=r.params.id,a=await e.getAgent(o);if(!a){i.code(404).send({error:`agent ${o} not found in registry`});return}if(a.distribution.uvx&&!a.distribution.npx&&!a.distribution.binary){i.send({agentId:a.id,version:a.version??"current",distribution:"uvx",installed:!1,message:"uvx agents resolve on first run; nothing to pre-install."});return}try{let d=await $n(a,[],{npmRegistry:s.npmRegistry}),c=a.distribution.npx?"npx":a.distribution.binary?"binary":"unknown";i.send({agentId:a.id,version:d.version,distribution:c,installed:!0,command:d.command})}catch(d){i.code(500).send({error:d.message})}}),t.post("/v1/agents/:id/sync",async(r,i)=>{let o=r.params.id;try{let{synced:a,skipped:d}=await n.syncFromAgent(o);return{synced:a.map(c=>({sessionId:c.sessionId,upstreamSessionId:c.upstreamSessionId,agentId:c.agentId,cwd:c.cwd,title:c.title,updatedAt:c.updatedAt})),skipped:d}}catch(a){let d=a;if(d.code===B.AgentNotInstalled){i.code(404).send({error:d.message});return}i.code(409).send({error:d.message})}})}function Rf(t,e,n){t.get("/v1/health",{config:{skipAuth:!0}},async()=>({status:"ok",version:e,configDigest:n}))}var $b=/^[A-Za-z0-9._-]+$/;function Tf(t,e){t.get("/v1/extensions",async()=>({extensions:e.list()})),t.get("/v1/extensions/:name",async(n,s)=>{let r=n.params.name,i=e.get(r);if(!i){s.code(404).send({error:`unknown extension: ${r}`});return}return i}),t.post("/v1/extensions",async(n,s)=>{let r=n.body??{},i=_b(r);if("error"in i){s.code(400).send({error:i.error});return}try{let o=e.register(i.config);s.code(201).send(o)}catch(o){ti(s,o)}}),t.delete("/v1/extensions/:name",async(n,s)=>{let r=n.params.name;try{await e.unregister(r),s.code(204).send()}catch(i){ti(s,i)}}),t.post("/v1/extensions/:name/start",async(n,s)=>{let r=n.params.name;try{let i=await e.startByName(r);s.code(200).send(i)}catch(i){ti(s,i)}}),t.post("/v1/extensions/:name/stop",async(n,s)=>{let r=n.params.name;try{let i=await e.stopByName(r);s.code(200).send(i)}catch(i){ti(s,i)}}),t.post("/v1/extensions/:name/restart",async(n,s)=>{let r=n.params.name;try{let i=await e.restartByName(r);s.code(200).send(i)}catch(i){ti(s,i)}})}function ti(t,e){let n=e.code,s=e.message??"unknown error";if(n==="NOT_FOUND"){t.code(404).send({error:s});return}if(n==="CONFLICT"){t.code(409).send({error:s});return}t.code(500).send({error:s})}function _b(t){let e=t.name;if(typeof e!="string"||!$b.test(e))return{error:"name must match [A-Za-z0-9._-]+"};let n=t.command;if(n!==void 0&&(!Array.isArray(n)||n.some(o=>typeof o!="string")))return{error:"command must be string[]"};let s=t.args;if(s!==void 0&&(!Array.isArray(s)||s.some(o=>typeof o!="string")))return{error:"args must be string[]"};let r=t.env;if(r!==void 0&&(typeof r!="object"||r===null||Array.isArray(r)))return{error:"env must be an object of string\u2192string"};if(r&&Object.values(r).some(o=>typeof o!="string"))return{error:"env values must be strings"};let i=t.enabled;return i!==void 0&&typeof i!="boolean"?{error:"enabled must be a boolean"}:{config:{name:e,command:n??[],args:s??[],env:r??{},enabled:i===void 0?!0:i}}}var Fb=/^[A-Za-z0-9._-]+$/;function Ef(t,e){t.get("/v1/transformers",async()=>({transformers:e.list()})),t.get("/v1/transformers/:name",async(n,s)=>{let r=n.params.name,i=e.get(r);if(!i){s.code(404).send({error:`unknown transformer: ${r}`});return}return i}),t.post("/v1/transformers",async(n,s)=>{let r=n.body??{},i=Ob(r);if("error"in i){s.code(400).send({error:i.error});return}try{let o=e.register(i.config);s.code(201).send(o)}catch(o){ni(s,o)}}),t.delete("/v1/transformers/:name",async(n,s)=>{let r=n.params.name;try{await e.unregister(r),s.code(204).send()}catch(i){ni(s,i)}}),t.post("/v1/transformers/:name/start",async(n,s)=>{let r=n.params.name;try{let i=await e.startByName(r);s.code(200).send(i)}catch(i){ni(s,i)}}),t.post("/v1/transformers/:name/stop",async(n,s)=>{let r=n.params.name;try{let i=await e.stopByName(r);s.code(200).send(i)}catch(i){ni(s,i)}}),t.post("/v1/transformers/:name/restart",async(n,s)=>{let r=n.params.name;try{let i=await e.restartByName(r);s.code(200).send(i)}catch(i){ni(s,i)}})}function ni(t,e){let n=e.code,s=e.message??"unknown error";if(n==="NOT_FOUND"){t.code(404).send({error:s});return}if(n==="CONFLICT"){t.code(409).send({error:s});return}t.code(500).send({error:s})}function Ob(t){let e=t.name;if(typeof e!="string"||!Fb.test(e))return{error:"name must match [A-Za-z0-9._-]+"};let n=t.command;if(n!==void 0&&(!Array.isArray(n)||n.some(o=>typeof o!="string")))return{error:"command must be string[]"};let s=t.args;if(s!==void 0&&(!Array.isArray(s)||s.some(o=>typeof o!="string")))return{error:"args must be string[]"};let r=t.env;if(r!==void 0&&(typeof r!="object"||r===null||Array.isArray(r)))return{error:"env must be an object of string\u2192string"};if(r&&Object.values(r).some(o=>typeof o!="string"))return{error:"env values must be strings"};let i=t.enabled;return i!==void 0&&typeof i!="boolean"?{error:"enabled must be a boolean"}:{config:{name:e,command:n??[],args:s??[],env:r??{},enabled:i===void 0?!0:i}}}function Pf(t,e){t.get("/v1/config",async()=>e)}import{z as sr}from"zod";ue();import*as Ln from"fs/promises";import*as Ff from"path";import{randomBytes as Lb,scrypt as Bb,timingSafeEqual as Nb}from"crypto";import{promisify as Db}from"util";var Of=Db(Bb);function Ad(){return Ff.join(P.home(),"password-hash")}var Mf=32768,$f=8,_f=1,Hb=64,Ub=16,Lf=128*1024*1024;async function Bf(t){if(typeof t!="string"||t.length===0)throw new Error("password must be a non-empty string");let e=Lb(Ub),n=await Of(t,e,Hb,{N:Mf,r:$f,p:_f,maxmem:Lf}),s=`scrypt$${Mf}$${$f}$${_f}$${e.toString("hex")}$${n.toString("hex")}
|
|
270
|
+
`;await Ln.mkdir(P.home(),{recursive:!0}),await Ln.writeFile(Ad(),s,{encoding:"utf8",mode:384})}async function Po(){try{return(await Ln.readFile(Ad(),"utf8")).trim().length>0}catch(t){if(t.code==="ENOENT")return!1;throw t}}async function Mo(t){if(typeof t!="string"||t.length===0)return!1;let e;try{e=(await Ln.readFile(Ad(),"utf8")).trim()}catch(c){if(c.code==="ENOENT")return!1;throw c}let n=e.split("$");if(n.length!==6||n[0]!=="scrypt")return!1;let s=parseInt(n[1],10),r=parseInt(n[2],10),i=parseInt(n[3],10);if(!Number.isFinite(s)||!Number.isFinite(r)||!Number.isFinite(i))return!1;let o=Buffer.from(n[4],"hex"),a=Buffer.from(n[5],"hex");if(o.length===0||a.length===0)return!1;let d=await Of(t,o,a.length,{N:s,r,p:i,maxmem:Lf});return d.length!==a.length?!1:Nb(d,a)}var jb=sr.object({password:sr.string().min(1),label:sr.string().min(1).max(256).optional(),ttlSec:sr.number().int().positive().optional()}),qb=sr.object({id:sr.string().optional()}).optional();function Nf(t,e){t.post("/v1/auth/login",{config:{skipAuth:!0}},async(n,s)=>{let r=Wb(n);if(e.rateLimiter.isBlocked(r))return s.code(429).send({error:"Too many failed attempts; try again later."});let i;try{i=jb.parse(n.body)}catch{return s.code(400).send({error:"Invalid request body"})}if(!await Po())return s.code(403).send({error:"No password configured. Run `hydra-acp auth password` on the daemon host."});if(!await Mo(i.password))return e.rateLimiter.recordFailure(r),s.code(401).send({error:"Invalid password"});e.rateLimiter.recordSuccess(r);let a=await e.store.issue({label:i.label,ttlSec:i.ttlSec});return s.code(200).send({session_token:a.token,id:a.id,expires_at:a.expiresAt})}),t.post("/v1/auth/logout",async(n,s)=>{let r;try{r=qb.parse(n.body??void 0)}catch{return s.code(400).send({error:"Invalid request body"})}let i=r?.id??n.authIdentity;if(!i||i==="service")return s.code(200).send({revoked:!1});let o=await e.store.revoke(i);return s.code(200).send({revoked:o})}),t.get("/v1/auth/verify",async(n,s)=>s.code(200).send({ok:!0})),t.get("/v1/auth/sessions",async(n,s)=>s.code(200).send({sessions:e.store.list()})),t.delete("/v1/auth/sessions/:id",async(n,s)=>{let r=n.params.id;return await e.store.revoke(r)?s.code(204).send():s.code(404).send({error:"Not found"})})}function Wb(t){return t.ip||"unknown"}Nr();$o();Xi();dt();import{nanoid as Pd}from"nanoid";Lt();import{randomBytes as Hf}from"crypto";function Uf(t,e){t.get("/acp",{websocket:!0},async(n,s)=>{let r=lf({headers:s.headers,url:s.url});if(!r||!await e.validator.validate(r)){n.close(4401,"Unauthorized");return}let i=e.processRegistry?.resolve(r),o=rr(n),a=new Kt(o),d={clientId:`hydra_client_${Pd(12)}`,processIdentity:i,attached:new Map};a.onClose(()=>{for(let f of d.attached.values())e.manager.get(f.sessionId)?.detach(f.clientId);d.attached.clear()});let c=(f,u)=>{if(d.attached.get(f)?.readonly){let g=new Error(`${u} not permitted on a read-only attachment`);throw g.code=B.PermissionDenied,g}};if(a.onRequest("initialize",async f=>{let u=zl.parse(f??{});u.clientInfo?.name&&(d.clientInfo={name:u.clientInfo.name,...u.clientInfo.version!==void 0?{version:u.clientInfo.version}:{}});let p=u.clientInfo?.version;return p&&i&&(i.kind==="extension"?e.onExtensionVersion?.(i.name,p):e.onTransformerVersion?.(i.name,p)),Vb()}),i&&e.extensionCommands){let f=e.extensionCommands;a.onRequest("hydra-acp/commands/register",async u=>{let p=u??{},g=Array.isArray(p.commands)?p.commands.map(h=>{if(!h||typeof h!="object")return;let w=h;if(typeof w.verb!="string")return;let v={verb:w.verb};return typeof w.argsHint=="string"&&(v.argsHint=w.argsHint),typeof w.description=="string"&&(v.description=w.description),v}).filter(h=>h!==void 0):[];return f.register(i.name,a,g),{ok:!0,registered:g.length}}),a.onClose(()=>{f.clear(i.name)})}if(i&&e.extensionMcp){let f=e.extensionMcp;a.onRequest("hydra-acp/mcp_tools/register",async u=>{let p=u??{},g=typeof p.instructions=="string"?p.instructions:void 0,h=Array.isArray(p.tools)?p.tools.map(w=>{if(!w||typeof w!="object")return;let v=w;if(typeof v.name!="string"||v.name.length===0||typeof v.description!="string"||v.inputSchema===null||typeof v.inputSchema!="object")return;let b={name:v.name,description:v.description,inputSchema:v.inputSchema};return v.outputSchema!==null&&typeof v.outputSchema=="object"&&(b.outputSchema=v.outputSchema),b}).filter(w=>w!==void 0):[];if(h.length===0)throw new Error("register_mcp_tools requires at least one tool");return f.register(i.name,a,g,h),{ok:!0,registered:h.length}}),a.onClose(()=>{f.clear(i.name)})}i?.kind==="transformer"&&(a.onRequest("hydra-acp/transformer/initialize",async f=>{let u=f??{},p=Array.isArray(u.intercepts)?u.intercepts.filter(g=>typeof g=="string"):[];if(e.transformers&&(e.transformers.registerConnection(i.name,a,p),e.manager?.defaultTransformers.includes(i.name))){let g=e.transformers.resolveChain([i.name])[0];if(g)for(let h of e.manager.liveSessions())h.addTransformer(g)}return{ack:!0}}),a.onClose(()=>{e.transformers?.deregisterConnection(i.name)}),a.onRequest("hydra-acp/message/emit",async f=>{let u=f??{},p=typeof u.sessionId=="string"?u.sessionId:void 0,g=typeof u.method=="string"?u.method:void 0,h=u.envelope,w=u.route;if(!p||!g)throw Object.assign(new Error("emit_message requires sessionId and method"),{code:-32602});let v=e.manager.get(p);if(!v)throw Object.assign(new Error(`session ${p} not found`),{code:B.SessionNotFound});let b=typeof u.respondsTo=="string"?u.respondsTo:void 0;if(b)return v.dischargeClaim(b,h),{ok:!0};if(w==="chain")return{ok:!0,response:await v.emitToChain(i.name,g,h)};if(w==="daemon")return{ok:!0,response:await v.emitToChain(i.name,g,h)};throw Object.assign(new Error(`unsupported route: ${JSON.stringify(w)}`),{code:-32602})}),a.onRequest("hydra-acp/session/request_permission",async f=>{let u=f??{},p=typeof u.sessionId=="string"?u.sessionId:void 0;if(!p)throw Object.assign(new Error("hydra-acp/session/request_permission requires sessionId"),{code:-32602});let g=e.manager.get(p);if(!g)throw Object.assign(new Error(`session ${p} not found`),{code:B.SessionNotFound});return g.requestPermissionFromClients(u)}),a.onRequest("hydra-acp/transformer/attach",async f=>Jb(f,i.name,e)),a.onRequest("hydra-acp/child_session/spawn",async f=>{let u=f??{},p=typeof u.agentId=="string"?u.agentId:e.defaultAgent,g=typeof u.cwd=="string"?u.cwd:void 0,h=typeof u.parentSessionId=="string"?u.parentSessionId:void 0,w=u._meta&&typeof u._meta=="object"?u._meta:void 0,v=w&&w["hydra-acp"]&&typeof w["hydra-acp"]=="object"?w["hydra-acp"]:void 0,b=v&&typeof v.title=="string"?v.title:void 0;if(!g&&h){let O=e.manager.get(h);O&&(g=O.cwd)}if(!g)throw Object.assign(new Error("child_session/spawn requires cwd (or a parentSessionId pointing at a live session whose cwd we can inherit)"),{code:-32602});let x=typeof u.interactive=="boolean"?u.interactive:!1;return{childSessionId:(await e.manager.create({agentId:p,cwd:g,parentSessionId:h,interactive:x,transformChain:[],title:b})).sessionId}}),a.onRequest("hydra-acp/session/fork",async f=>{let u=f??{};if(typeof u.sessionId!="string")throw Object.assign(new Error("fork_session requires sessionId"),{code:B.InvalidParams});let p=typeof u.forkAt=="string"?u.forkAt:void 0,g=typeof u.cwd=="string"?u.cwd:void 0,h=typeof u.agentId=="string"?u.agentId:void 0;return await e.manager.forkSession(u.sessionId,{...p!==void 0?{forkAt:p}:{},...g!==void 0?{cwd:g}:{},...h!==void 0?{agentId:h}:{}})}),a.onRequest("hydra-acp/session/delete",async f=>{let u=f??{};if(typeof u.sessionId!="string")throw Object.assign(new Error("hydra-acp/session/delete requires sessionId"),{code:B.InvalidParams});let p=await e.manager.resolveCanonicalId(u.sessionId)??u.sessionId,g=e.manager.get(p);if(g)return await g.close({deleteRecord:!0}),{deleted:!0,sessionId:p};if(!await e.manager.deleteRecord(p))throw Object.assign(new Error(`session ${p} not found`),{code:B.SessionNotFound});return{deleted:!0,sessionId:p}}),a.onRequest("hydra-acp/child_session/await",async f=>{let u=f??{},p=typeof u.childSessionId=="string"?u.childSessionId:void 0,g=u.until==="idle"?"idle":"turn_complete",h=typeof u.timeoutMs=="number"?Math.min(u.timeoutMs,30*6e4):5*6e4;if(!p)throw Object.assign(new Error("await_child requires childSessionId"),{code:-32602});let w=e.manager.get(p);if(!w)throw Object.assign(new Error(`child session ${p} not found`),{code:B.SessionNotFound});return new Promise(v=>{let b=[],x,C=()=>{clearTimeout(O),x?.(),v({entries:b})};x=w.onBroadcast(q=>{b.push(q),g==="turn_complete"&&q.params?.update?.sessionUpdate==="turn_complete"&&C()});let O=setTimeout(C,h);typeof O.unref=="function"&&O.unref(),w.onClose(()=>C())})}),a.onRequest("hydra-acp/child_session/close",async f=>{let u=f??{},p=typeof u.childSessionId=="string"?u.childSessionId:void 0;if(!p)throw Object.assign(new Error("close_child_session requires childSessionId"),{code:-32602});let g=e.manager.get(p);return g&&await g.close({deleteRecord:!1}),{ok:!0}}),a.onRequest("hydra-acp/connection/keep_alive",async f=>{let u=f??{},p=typeof u.token=="string"?u.token:void 0,g=typeof u.sessionId=="string"?u.sessionId:void 0,h=typeof u.estimatedRemainingMs=="number"?u.estimatedRemainingMs:void 0;return p&&g&&e.manager.get(g)?.keepAliveClaim(p,h),{ok:!0}})),a.onRequest("hydra-acp/session/tool_content",async f=>{let u=f??{};if(typeof u.sessionId!="string"||typeof u.hash!="string")throw Object.assign(new Error("hydra-acp/session/tool_content requires sessionId and hash"),{code:B.InvalidParams});let p=await e.manager.resolveCanonicalId(u.sessionId)??u.sessionId,g=await e.manager.loadToolBlob(p,u.hash);if(g===null)throw Object.assign(new Error("tool content not found"),{code:B.SessionNotFound});return{content:g}}),a.onRequest("session/new",async f=>{let u=Jl.parse(f),p=wt(f?._meta),g=Array.isArray(p.transformers)&&p.transformers.every(N=>typeof N=="string")?p.transformers:e.manager.defaultTransformers??[],h=e.transformers?.resolveChain(g)??[],w,v,b=u.mcpServers;if(p.mcpStdin===!0&&e.mcpTokenRegistry!==void 0&&e.getDaemonOrigin!==void 0){w=Hf(32).toString("hex"),v=e.mcpTokenRegistry.reserve(w);let F={name:"hydra-acp-stdin",type:"http",url:`${e.getDaemonOrigin()}/mcp/hydra-acp-stdin`,headers:[{name:"Authorization",value:`Bearer ${w}`}]};b=[...u.mcpServers??[],F]}let x=Fo(e);x!==void 0&&(b=[...b??[],...x.descriptors]);let C;try{C=await e.manager.create({cwd:u.cwd,agentId:p.agentId??e.defaultAgent,mcpServers:b,title:p.title,agentArgs:p.agentArgs,model:p.model,onInstallProgress:Df(a),transformChain:h,originatingClient:d.clientInfo,...p.interactive!==void 0?{interactive:p.interactive}:{}})}catch(N){throw v!==void 0&&v.abandon(N instanceof Error?N:void 0),x!==void 0&&x.abandon(N instanceof Error?N:void 0),N}if(w!==void 0&&v!==void 0&&e.mcpTokenRegistry!==void 0){let N=w,F=e.mcpTokenRegistry;v.complete(C),C.onClose(()=>{F.unbind(N)})}x!==void 0&&x.bindToSession(C);let O=_o(a,C,d),{entries:q}=await C.attach(O,"full");d.attached.set(C.sessionId,{sessionId:C.sessionId,clientId:O.clientId,readonly:!1}),setImmediate(()=>{(async()=>{for(let N of q)await a.notify(N.method,N.params).catch(()=>{})})()});let W=Cd(C),Q=Rd(C);return{sessionId:C.sessionId,...W?{modes:W}:{},...Q?{models:Q}:{},configOptions:C.buildConfigOptions(),_meta:Td(e.manager,C,{clientId:O.clientId})}}),a.onRequest("session/attach",async f=>{let u=Kl.parse(f),p=u.clientInfo?.version;p&&i&&(i.kind==="extension"?e.onExtensionVersion?.(i.name,p):e.onTransformerVersion?.(i.name,p));let g=wt(u._meta),h=g.resume,w=g.readonly===!0;t.log.info(`session/attach sessionId=${u.sessionId} hasResumeHints=${!!h} readonly=${w}`);let v=h?u.sessionId:await e.manager.resolveCanonicalId(u.sessionId)??u.sessionId,b=e.manager.get(v);if(!b&&w){let N=await e.manager.loadFromDisk(v);if(!N){let J=new Error(`session ${u.sessionId} not found`);throw J.code=B.SessionNotFound,J}let F=await e.manager.loadHistory(v),U=u.clientId??`cli_${Pd(8)}`;d.attached.set(N.hydraSessionId,{sessionId:N.hydraSessionId,clientId:U,readonly:!0}),t.log.info(`session/attach OK (viewer) sessionId=${N.hydraSessionId} clientId=${U} attachedCount=${d.attached.size} replayed=${F.length}`);for(let J of F)await a.notify(J.method,J.params).catch(()=>{});return{sessionId:N.hydraSessionId,clientId:U,connectedClients:[U],historyPolicy:"full",replayed:F.length,_meta:Kb(N)}}if(!b){let N=await e.manager.loadFromDisk(v),F=N;if(h&&(F={...N,hydraSessionId:u.sessionId,upstreamSessionId:h.upstreamSessionId,agentId:h.agentId,cwd:h.cwd,...h.title!==void 0?{title:h.title}:{},...h.agentArgs!==void 0?{agentArgs:h.agentArgs}:{}}),!F){let ie=new Error(`session ${u.sessionId} not found and no resume hints provided`);throw ie.code=B.SessionNotFound,ie}let U=F.originatingClient?F:{...F,originatingClient:d.clientInfo},J=Fo(e);try{b=await e.manager.resurrect({...U,mcpServers:J?.descriptors,onInstallProgress:Df(a)})}catch(ie){throw J!==void 0&&J.abandon(ie instanceof Error?ie:void 0),ie}J!==void 0&&J.bindToSession(b),Ed(b,e)}let x=_o(a,b,d,u.clientInfo,u.clientId),C=g.replayMode==="drip",{entries:O,appliedPolicy:q}=await b.attach(x,u.historyPolicy,{afterMessageId:u.afterMessageId,raw:C,...g.toolContent!==void 0?{toolContent:g.toolContent}:{}});if(d.attached.set(b.sessionId,{sessionId:b.sessionId,clientId:x.clientId,readonly:w}),t.log.info(`session/attach OK sessionId=${b.sessionId} clientId=${x.clientId} attachedCount=${d.attached.size} requestedPolicy=${u.historyPolicy} appliedPolicy=${q} replayed=${O.length} readonly=${w}${C?" replayMode=drip":""}`),C){let N=g.dripSpeed&&g.dripSpeed>0?g.dripSpeed:1,F=750;(async()=>{let U=null;for(let J of O){let ie=typeof J.recordedAt=="number"?J.recordedAt:null;if(U!==null&&ie!==null){let be=Math.min(F,Math.max(0,(ie-U)/N));be>0&&await new Promise(te=>setTimeout(te,be))}ie!==null&&(U=ie);try{await a.notify(J.method,J.params)}catch{return}}})()}else for(let F=0;F<O.length;F++){let U=O[F],J=a.notify(U.method,U.params).catch(()=>{});(F+1)%200===0&&await J}b.replayPendingPermissions(x);let W=Cd(b),Q=Rd(b);return{sessionId:b.sessionId,clientId:x.clientId,connectedClients:b.connectedClients(x.clientId),historyPolicy:q,replayed:O.length,...W?{modes:W}:{},...Q?{models:Q}:{},configOptions:b.buildConfigOptions(),_meta:Td(e.manager,b)}}),a.onRequest("session/detach",async f=>{let u=Vl.parse(f),p=d.attached.get(u.sessionId);if(!p){let h=new Error("client not attached to that session");throw h.code=B.SessionNotFound,h}let g=e.manager.get(u.sessionId);return g?.detach(p.clientId),d.attached.delete(u.sessionId),g&&e.manager.reapIfOrphanedNonInteractive(u.sessionId),{sessionId:u.sessionId,_meta:{[Ct]:{detachStatus:"detached"}}}}),a.onRequest("session/list",async f=>{let u=Yl.parse(f??{});return{sessions:(await e.manager.list({cwd:u.cwd})).filter(w=>w.originatingClient?.name!==cs).map(Gl)}}),a.onRequest("hydra-acp/agents/list",async()=>{if(!e.registry){let f=new Error("agent registry unavailable");throw f.code=B.InternalError,f}return zs(e.registry)}),a.onRequest("session/prompt",async f=>{let u=Xl.parse(f);c(u.sessionId,"session/prompt");let p=d.attached.get(u.sessionId);if(!p){t.log.warn(`session/prompt rejected: not attached sessionId=${u.sessionId} attachedKeys=[${[...d.attached.keys()].join(",")}]`);let h=new Error("not attached to session");throw h.code=B.SessionNotFound,h}let g=e.manager.get(u.sessionId);if(!g){let h=await e.manager.loadFromDisk(u.sessionId);if(!h){let b=new Error(`session ${u.sessionId} not found`);throw b.code=B.SessionNotFound,b}t.log.info(`session/prompt auto-resurrecting cold sessionId=${u.sessionId}`);let w=Fo(e);try{g=await e.manager.resurrect({...h,mcpServers:w?.descriptors})}catch(b){throw w!==void 0&&w.abandon(b instanceof Error?b:void 0),b}w!==void 0&&w.bindToSession(g),Ed(g,e);let v=_o(a,g,d,void 0,p.clientId);await g.attach(v,"none")}return g.prompt(p.clientId,u)});let l=f=>{let u;try{u=Ji.parse(f)}catch(h){t.log.warn(`session/cancel: invalid params: ${h.message}`);return}let p=d.attached.get(u.sessionId);if(!p)return;if(p.readonly){t.log.warn(`session/cancel dropped (readonly attachment) sessionId=${u.sessionId}`);return}let g=e.manager.get(u.sessionId);g&&g.cancel(p.clientId).catch(h=>{t.log.warn(`session/cancel for ${u.sessionId}: ${h.message}`)})};a.onNotification("session/cancel",l),a.onRequest("session/cancel",async f=>{let u=Ji.parse(f);return c(u.sessionId,"session/cancel"),l(f),null}),a.onRequest("hydra-acp/prompt/cancel",async f=>{let u=eu.parse(f);c(u.sessionId,"hydra-acp/prompt/cancel");let p=e.manager.get(u.sessionId);if(!p){let g=new Error(`session ${u.sessionId} not found`);throw g.code=B.SessionNotFound,g}return p.cancelQueuedPrompt(u.messageId)}),a.onRequest("hydra-acp/session/force_cancel",async f=>{let u=Ji.parse(f);c(u.sessionId,"hydra-acp/session/force_cancel");let p=e.manager.get(u.sessionId);if(!p){let g=new Error(`session ${u.sessionId} not found`);throw g.code=B.SessionNotFound,g}return p.forceCancel()}),a.onRequest("hydra-acp/prompt/update",async f=>{let u=tu.parse(f);c(u.sessionId,"hydra-acp/prompt/update");let p=e.manager.get(u.sessionId);if(!p){let g=new Error(`session ${u.sessionId} not found`);throw g.code=B.SessionNotFound,g}return p.updateQueuedPrompt(u.messageId,u.prompt)}),a.onRequest("hydra-acp/prompt/amend",async f=>{let u=nu.parse(f);c(u.sessionId,"hydra-acp/prompt/amend");let p=d.attached.get(u.sessionId);if(!p){let h=new Error("not attached to session");throw h.code=B.SessionNotFound,h}let g=e.manager.get(u.sessionId);if(!g){let h=new Error(`session ${u.sessionId} not found`);throw h.code=B.SessionNotFound,h}return g.amendPrompt(p.clientId,u)}),a.onRequest("session/load",async f=>{let u=f??{},p=typeof u.sessionId=="string"?u.sessionId:void 0;if(!p){let C=new Error("session/load requires sessionId");throw C.code=B.InvalidParams,C}let g=await e.manager.resolveCanonicalId(p)??p,h=e.manager.get(g);if(!h){let C=await e.manager.loadFromDisk(g);if(!C){let q=new Error(`session ${p} not found in memory or on disk`);throw q.code=B.SessionNotFound,q}let O=Fo(e);try{h=await e.manager.resurrect({...C,mcpServers:O?.descriptors})}catch(q){throw O!==void 0&&O.abandon(q instanceof Error?q:void 0),q}O!==void 0&&O.bindToSession(h),Ed(h,e)}let w=_o(a,h,d),{entries:v}=await h.attach(w,"pending_only");d.attached.set(h.sessionId,{sessionId:h.sessionId,clientId:w.clientId,readonly:!1});for(let C of v)await a.notify(C.method,C.params);h.replayPendingPermissions(w);let b=Cd(h),x=Rd(h);return{sessionId:h.sessionId,...b?{modes:b}:{},...x?{models:x}:{},configOptions:h.buildConfigOptions(),_meta:Td(e.manager,h,{clientId:w.clientId})}}),a.onRequest("session/set_model",async f=>{let u=f?.sessionId;typeof u=="string"&&c(u,"session/set_model");let p=zb(f,e.manager);if(p.kind==="error"){t.log.warn(p.logMessage);let w=new Error(p.message);throw w.code=p.code,w}if(p.kind==="no_op")return t.log.warn(p.logMessage),await a.notify("session/update",{sessionId:p.sessionId,update:{sessionUpdate:"current_model_update",currentModel:p.currentModel}}).catch(()=>{}),null;t.log.info(p.logMessage);let{modelId:g}=p,h=await p.session.forwardRequest("session/set_model",{...f,modelId:g});return p.session.applyModelChange(g),h}),a.onRequest("session/set_mode",async f=>{let u=f,p=u?.sessionId;if(typeof p=="string"&&c(p,"session/set_mode"),!u||typeof u.sessionId!="string"){let w=new Error("session/set_mode requires string sessionId");throw w.code=B.InvalidParams,w}if(typeof u.modeId!="string"){let w=new Error("session/set_mode requires string modeId");throw w.code=B.InvalidParams,w}let g=e.manager.get(u.sessionId);if(!g){let w=new Error(`session ${u.sessionId} not found`);throw w.code=B.SessionNotFound,w}let h=await g.forwardRequest("session/set_mode",f);return g.applyModeChange(u.modeId),h}),a.onRequest("session/set_config_option",async f=>{let u=f,p=v=>{let b=new Error(v);return b.code=B.InvalidParams,b},g=u?.sessionId;if(typeof g=="string"&&c(g,"session/set_config_option"),!u||typeof u.sessionId!="string")throw p("session/set_config_option requires string sessionId");if(typeof u.configId!="string")throw p("session/set_config_option requires string configId");if(typeof u.value!="string")throw p("session/set_config_option requires string value");let h=e.manager.get(u.sessionId);if(!h){let v=new Error(`session ${u.sessionId} not found`);throw v.code=B.SessionNotFound,v}let w=h.buildConfigOptions().find(v=>v.id===u.configId);if(!w)throw p(`unknown configId ${JSON.stringify(u.configId)} for this session`);if(!w.options.some(v=>v.value===u.value))throw p(`value ${JSON.stringify(u.value)} is not valid for configId ${JSON.stringify(u.configId)}`);switch(u.configId){case"model":{u.value!==h.currentModel&&await h.forwardRequest("session/set_model",{sessionId:u.sessionId,modelId:u.value}),h.applyModelChange(u.value);break}case"mode":{u.value!==h.currentMode&&await h.forwardRequest("session/set_mode",{sessionId:u.sessionId,modeId:u.value}),h.applyModeChange(u.value);break}case"agent":{u.value!==h.agentId&&await h.setAgent(u.value);break}default:throw p(`configId ${JSON.stringify(u.configId)} is not settable`)}return{configOptions:h.buildConfigOptions()}}),a.setDefaultHandler(async(f,u)=>{if(!u.startsWith("session/")||f===null||typeof f!="object"){let h=new Error(`Method not found: ${u}`);throw h.code=B.MethodNotFound,h}let p=f.sessionId;if(typeof p!="string"){let h=new Error(`Method not found: ${u}`);throw h.code=B.MethodNotFound,h}c(p,u);let g=e.manager.get(p);if(!g){let h=new Error(`session ${p} not found`);throw h.code=B.SessionNotFound,h}return g.forwardRequest(u,f)})})}function Df(t){return e=>{let n={agentId:e.agentId,version:e.version,source:e.source,phase:e.phase};"receivedBytes"in e&&(n.receivedBytes=e.receivedBytes),"totalBytes"in e&&(n.totalBytes=e.totalBytes),"packageSpec"in e&&(n.packageSpec=e.packageSpec),t.notify(Ki,n).catch(()=>{})}}function Cd(t){let e=t.availableModes();if(e.length===0)return;let n=e.map(r=>{let i={id:r.id,name:r.name??r.id};return r.description!==void 0&&(i.description=r.description),i});return{currentModeId:t.currentMode??e[0].id,availableModes:n}}function Rd(t){let e=t.availableModels();if(e.length===0)return;let n=e.map(r=>{let i={modelId:r.modelId};return r.name!==void 0&&(i.name=r.name),r.description!==void 0&&(i.description=r.description),i});return{currentModelId:t.currentModel??e[0].modelId,availableModels:n}}function zb(t,e){if(!t||typeof t!="object")return{kind:"error",code:B.InvalidParams,message:"session/set_model requires params",logMessage:"session/set_model rejected: params not an object"};let n=t;if(typeof n.sessionId!="string")return{kind:"error",code:B.InvalidParams,message:"session/set_model requires string sessionId",logMessage:"session/set_model rejected: missing/non-string sessionId"};if(typeof n.modelId!="string")return{kind:"error",code:B.InvalidParams,message:"session/set_model requires string modelId",logMessage:`session/set_model rejected: missing/non-string modelId sessionId=${n.sessionId}`};let s=e.get(n.sessionId);if(!s)return{kind:"error",code:B.SessionNotFound,message:`session ${n.sessionId} not found`,logMessage:`session/set_model rejected: session not found sessionId=${n.sessionId}`};let r=s.availableModels(),i=Ks(n.modelId,r);if(i.kind==="none")return{kind:"ok",session:s,modelId:n.modelId,logMessage:`session/set_model passthrough (no availableModels) sessionId=${n.sessionId} modelId=${JSON.stringify(n.modelId)}`};if(i.kind==="exact")return{kind:"ok",session:s,modelId:n.modelId,logMessage:`session/set_model accepted sessionId=${n.sessionId} modelId=${JSON.stringify(n.modelId)}`};if(i.kind==="resolved")return{kind:"ok",session:s,modelId:i.modelId,logMessage:`session/set_model resolved sessionId=${n.sessionId} requested=${JSON.stringify(n.modelId)} \u2192 ${JSON.stringify(i.modelId)}`};let o=r.map(d=>d.modelId).join(", "),a=i.kind==="ambiguous"?`ambiguous (trailing-segment matches [${i.candidates.join(", ")}])`:"not in availableModels";return s.currentModel!==void 0&&s.currentModel.length>0?{kind:"no_op",session:s,sessionId:n.sessionId,currentModel:s.currentModel,logMessage:`session/set_model no_op (resyncing client) sessionId=${n.sessionId} requested=${JSON.stringify(n.modelId)} ${a} actual=${JSON.stringify(s.currentModel)} agentId=${s.agentId} known=[${o}]`}:{kind:"error",code:B.InvalidParams,message:`model "${n.modelId}" is ${a==="not in availableModels"?"not in this session's availableModels":a} (agent ${s.agentId}); known models: ${o}`,logMessage:`session/set_model rejected sessionId=${n.sessionId} modelId=${JSON.stringify(n.modelId)} ${a} agentId=${s.agentId} known=[${o}] (no current model to fall back to)`}}async function Jb(t,e,n){let s=t??{},r=typeof s.sessionId=="string"?s.sessionId:void 0;if(!r)throw Object.assign(new Error("transformer/attach requires sessionId"),{code:B.InvalidParams});if(!n.transformers)throw Object.assign(new Error("transformer manager not configured"),{code:B.InternalError});let i=n.transformers.resolveChain([e])[0];if(!i)throw Object.assign(new Error(`transformer ${e} is not connected (call hydra-acp/transformer/initialize first)`),{code:B.InternalError});let o=n.manager.get(r);if(!o)throw Object.assign(new Error(`session ${r} not found`),{code:B.SessionNotFound});return o.addTransformer(i),{ok:!0}}function Kb(t){let e={sessionId:t.hydraSessionId,upstreamSessionId:t.upstreamSessionId,cwd:t.cwd,title:t.title,agentId:t.agentId,currentModel:t.currentModel,currentUsage:t.currentUsage,forkedFromSessionId:t.forkedFromSessionId,forkedFromMessageId:t.forkedFromMessageId,originatingClient:t.originatingClient,interactive:t.interactive,updatedAt:t.createdAt??new Date().toISOString(),attachedClients:0,status:"cold",busy:!1,awaitingInput:!1},n={currentMode:t.currentMode,agentArgs:t.agentArgs,availableCommands:t.agentCommands,availableModes:t.agentModes,availableModels:t.agentModels};return{[Ct]:zi(e,n)}}function Td(t,e,n={}){let s=t.liveListEntry(e),r={clientId:n.clientId,currentMode:e.currentMode,agentArgs:e.agentArgs,availableCommands:e.mergedAvailableCommands(),availableModes:e.availableModes(),availableModels:e.availableModels(),turnStartedAt:e.turnStartedAt,agentCapabilities:e.agentCapabilities,queue:e.queueSnapshot()};return Wi(e.agentMeta,zi(s,r))}function Vb(){return{protocolVersion:yt,agentInfo:{name:"hydra",version:me},agentCapabilities:{promptCapabilities:{image:!0,audio:!0,embeddedContext:!0},mcpCapabilities:{http:!0,sse:!0},loadSession:!0,sessionCapabilities:{attach:{},list:{}}},authMethods:[{id:"bearer-token",description:"Bearer token presented at WS upgrade"}],_meta:Wi(void 0,{prompt:{queueing:!0,cancelling:!0,updating:!0,amending:!0,pipelining:!1},agents:{list:!0,installProgress:!0}})}}function Ed(t,e){if(!(!e.transformers||!e.manager))for(let n of e.manager.defaultTransformers){let s=e.transformers.resolveChain([n])[0];s&&t.addTransformer(s)}}function _o(t,e,n,s,r){return{clientId:r??`cli_${Pd(8)}`,connection:t,clientInfo:s}}function Fo(t){if(t.extensionMcp===void 0||t.mcpTokenRegistry===void 0||t.getDaemonOrigin===void 0)return;let e=t.extensionMcp.list();if(e.length===0)return;let n=Hf(32).toString("hex"),s=t.mcpTokenRegistry.reserve(n),r=t.getDaemonOrigin(),i=e.map(a=>({name:a,type:"http",url:`${r}/mcp/${a}`,headers:[{name:"Authorization",value:`Bearer ${n}`}]})),o=t.mcpTokenRegistry;return{descriptors:i,bindToSession:a=>{s.complete(a),a.onClose(()=>{o.unbind(n)})},abandon:a=>s.abandon(a)}}var Oo=class{byToken=new Map;reserve(e){if(this.byToken.has(e))throw new Error("mcp token already bound");let n,s,r=new Promise((o,a)=>{n=o,s=a});r.catch(()=>{});let i={session:void 0,sessionReady:r,disposers:[]};return this.byToken.set(e,i),{complete:o=>{i.session=o,n(o)},abandon:o=>{this.byToken.delete(e),s(o??new Error("mcp token reservation abandoned"))}}}bind(e,n){let{complete:s}=this.reserve(e);s(n)}lookup(e){return this.byToken.get(e)}addDisposer(e,n){let s=this.byToken.get(e);s!==void 0&&s.disposers.push(n)}async unbind(e){let n=this.byToken.get(e);if(n!==void 0){this.byToken.delete(e);for(let s of n.disposers)try{await s()}catch{}}}size(){return this.byToken.size}};import{randomUUID as Yb}from"crypto";import{McpServer as Qb}from"@modelcontextprotocol/sdk/server/mcp.js";import{StreamableHTTPServerTransport as Gb}from"@modelcontextprotocol/sdk/server/streamableHttp.js";import{z as tt}from"zod";var jf="Bearer ";function Lo(t){let e=t.headers.authorization;if(typeof e!="string"||!e.startsWith(jf))return;let n=e.slice(jf.length).trim();return n.length>0?n:void 0}function Xb(t){let e=new Qb({name:"hydra-acp-stdin",version:"1.0.0"},{instructions:"Piped input from `hydra cat --stream` is exposed here as a byte stream. Use `tail` for the latest N bytes (good for finding the end of a log), `head` for the first N bytes (good for headers/preamble), `read` for windowed reads against an absolute byte cursor, `wait_for_more` to block until new bytes arrive past a cursor, and `info` for the current cursors/capacity/closed status. Byte payloads come back base64-encoded."});return e.registerTool("tail",{description:"Return the most recent `bytes` bytes of piped stdin (capped server-side, default 64 KiB max). `truncated:true` means older bytes existed but have been evicted from the ring.",inputSchema:{bytes:tt.number().int().min(1).describe("How many trailing bytes to return.")}},async({bytes:n})=>{let s=t.streamTail(n);return{content:[{type:"text",text:JSON.stringify(s)}],structuredContent:s}}),e.registerTool("head",{description:"Return the first `bytes` bytes of piped stdin (capped server-side, default 64 KiB max). `truncated:true` means the head has already been evicted from the ring and the returned bytes start at the oldest still-resident cursor.",inputSchema:{bytes:tt.number().int().min(1).describe("How many leading bytes to return.")}},async({bytes:n})=>{let s=t.streamHead(n);return{content:[{type:"text",text:JSON.stringify(s)}],structuredContent:s}}),e.registerTool("read",{description:"Read up to `max_bytes` bytes starting at absolute byte `cursor`. Returns `{bytes, nextCursor, gap?, eof?}` \u2014 `gap` is the number of bytes silently skipped because the ring had evicted them; `eof:true` means the producer closed and there is nothing left to read.",inputSchema:{cursor:tt.number().int().min(0).describe("Absolute byte offset to start reading from. Use 0 to read from the very beginning (may produce a gap if old bytes have been evicted)."),max_bytes:tt.number().int().min(1).optional().describe("Optional cap on how many bytes to return. Server caps at 64 KiB regardless."),wait_ms:tt.number().int().min(0).optional().describe("If no bytes are available, block up to this many ms for more (capped server-side at 60_000).")}},async({cursor:n,max_bytes:s,wait_ms:r})=>{let i=await t.streamRead(n,s,r);return{content:[{type:"text",text:JSON.stringify(i)}],structuredContent:i}}),e.registerTool("wait_for_more",{description:"Block until bytes are available past `cursor`, the stream closes, or `timeout_ms` elapses. Returns one of {data, eof, timeout} plus the current `writeCursor`. Use this when you've consumed everything up to a cursor and want to wait for more without busy-polling.",inputSchema:{cursor:tt.number().int().min(0).describe("The cursor you've already consumed up to."),timeout_ms:tt.number().int().min(0).describe("Maximum ms to block (server caps at 60_000).")}},async({cursor:n,timeout_ms:s})=>{let r=await t.streamWaitFor(n,s),i=t.streamInfo(),o={outcome:r,writeCursor:i.writeCursor,closed:i.closed};return{content:[{type:"text",text:JSON.stringify(o)}],structuredContent:o}}),e.registerTool("grep",{description:"Scan piped stdin line-by-line and return lines matching `pattern`. Prefer this over `read` when the question is 'find lines that mention X' \u2014 it filters server-side so you don't pull and decode 64 KiB base64 windows. Returns `{matches: [{cursor, line, before?, after?}], truncated, nextCursor, gap?, scannedBytes, eof?}`. Lines come back as decoded UTF-8 strings (not base64). When `truncated:true`, re-call with `cursor: nextCursor` to resume.",inputSchema:{pattern:tt.string().min(1).describe("Search pattern. Treated as a JavaScript regular expression by default (set `regex:false` for a literal substring match)."),regex:tt.boolean().optional().describe("Default true. Pass false to treat `pattern` as a literal substring."),case_insensitive:tt.boolean().optional().describe("Default false. Pass true for case-insensitive matching."),invert:tt.boolean().optional().describe("Default false. Pass true to return lines that do NOT match the pattern."),max_matches:tt.number().int().min(1).optional().describe("Default 100. Capped server-side at 1000."),max_bytes:tt.number().int().min(1).optional().describe("Default 64 KiB output. Capped server-side at 256 KiB."),context_before:tt.number().int().min(0).optional().describe("Default 0. Number of lines before each match to include (capped at 20)."),context_after:tt.number().int().min(0).optional().describe("Default 0. Number of lines after each match to include (capped at 20)."),cursor:tt.number().int().min(0).optional().describe("Optional absolute byte offset to start scanning from. Omit to scan from the oldest still-resident byte. Pass the `nextCursor` from a previous truncated call to resume.")}},async n=>{let s={pattern:n.pattern};n.regex!==void 0&&(s.regex=n.regex),n.case_insensitive!==void 0&&(s.caseInsensitive=n.case_insensitive),n.invert!==void 0&&(s.invert=n.invert),n.max_matches!==void 0&&(s.maxMatches=n.max_matches),n.max_bytes!==void 0&&(s.maxBytes=n.max_bytes),n.context_before!==void 0&&(s.contextBefore=n.context_before),n.context_after!==void 0&&(s.contextAfter=n.context_after),n.cursor!==void 0&&(s.cursor=n.cursor);let r=t.streamGrep(s),i=r;return{content:[{type:"text",text:JSON.stringify(r)}],structuredContent:i}}),e.registerTool("info",{description:"Report cursor / capacity / closed state of the stdin ring. Cheap; safe to call repeatedly.",inputSchema:{}},async()=>{let n=t.streamInfo();return{content:[{type:"text",text:JSON.stringify(n)}],structuredContent:n}}),e}var Zb=1e4;function qf(t,e){let n=new Map;async function s(o,a){let d=n.get(o);if(d!==void 0)return d.transport;let c=Xb(a),l=new Gb({sessionIdGenerator:()=>Yb()});await c.connect(l);let f={server:c,transport:l};return n.set(o,f),e.addDisposer(o,async()=>{n.delete(o);try{await l.close()}catch{}try{await c.close()}catch{}}),l}async function r(o,a){let d=Lo(o);if(d===void 0){a.code(401).send({error:"missing bearer token"});return}let c=e.lookup(d);if(c===void 0){a.code(404).send({error:"unknown stdin token"});return}let l;if(c.session!==void 0)l=c.session;else{let u,p=new Promise(h=>{u=setTimeout(()=>h(void 0),Zb)}),g=await Promise.race([c.sessionReady.catch(()=>{}),p]);if(u!==void 0&&clearTimeout(u),g===void 0){a.code(503).send({error:"session not ready"});return}l=g}let f=await s(d,l);a.hijack(),await f.handleRequest(o.raw,a.raw,o.body)}let i={config:{skipAuth:!0}};t.post("/mcp/hydra-acp-stdin",i,async(o,a)=>{await r(o,a)}),t.get("/mcp/hydra-acp-stdin",i,async(o,a)=>{await r(o,a)}),t.delete("/mcp/hydra-acp-stdin",i,async(o,a)=>{await r(o,a)})}var Bo=class{byName=new Map;changeHandlers=[];register(e,n,s,r){this.byName.set(e,{connection:n,instructions:s,tools:[...r]}),this.fireChanged(e,"register")}clear(e){this.byName.delete(e)&&this.fireChanged(e,"clear")}lookup(e){return this.byName.get(e)}list(){return Array.from(this.byName.keys())}onChange(e){return this.changeHandlers.push(e),()=>{let n=this.changeHandlers.indexOf(e);n>=0&&this.changeHandlers.splice(n,1)}}fireChanged(e,n){for(let s of this.changeHandlers)try{s(e,n)}catch{}}};import{StreamableHTTPServerTransport as ov}from"@modelcontextprotocol/sdk/server/streamableHttp.js";import{randomUUID as av}from"crypto";import{Server as ev}from"@modelcontextprotocol/sdk/server/index.js";import{CallToolRequestSchema as tv,ListToolsRequestSchema as nv}from"@modelcontextprotocol/sdk/types.js";var sv=6e4;function Wf(t,e,n,s={}){let r=s.invokeTimeoutMs??sv,i=typeof n=="function"?async()=>n():async()=>n,o=new ev({name:t,version:"1.0.0"},{capabilities:{tools:{listChanged:!1}},...e.instructions!==void 0?{instructions:e.instructions}:{}}),a=new Map(e.tools.map(d=>[d.name,d]));return o.setRequestHandler(nv,async()=>({tools:e.tools.map(d=>({name:d.name,description:d.description,inputSchema:d.inputSchema,...d.outputSchema!==void 0?{outputSchema:d.outputSchema}:{}}))})),o.setRequestHandler(tv,async d=>{let c=d.params.name;if(!a.has(c))return No(`unknown tool: ${c}`);try{let l=await i(),f=await rv(e.connection,t,c,d.params.arguments??{},l,r);return iv(f,c)}catch(l){return No(l instanceof Error?l.message:String(l))}}),o}async function rv(t,e,n,s,r,i){let o,a=new Promise((d,c)=>{o=setTimeout(()=>c(new Error(`extension timeout after ${i}ms`)),i)});try{return await Promise.race([t.request("hydra-acp/mcp_tools/invoke",{server:e,tool:n,args:s,sessionId:r}),a])}finally{o!==void 0&&clearTimeout(o)}}function iv(t,e){if(t===null||typeof t!="object")return No(`extension ${e} returned non-object`);let n=t;return Array.isArray(n.content)?n:No(`extension ${e} omitted content array`)}function No(t){return{content:[{type:"text",text:t}],isError:!0}}var dv=1e4;function zf(t,e,n,s={}){let r=new Map;async function i(l){try{await l.transport.close()}catch{}try{await l.server.close()}catch{}}function o(l){for(let f of r.values()){let u=f.get(l);u!==void 0&&(f.delete(l),i(u))}}n.onChange(l=>{o(l)});async function a(l,f){let u=r.get(l);u===void 0&&(u=new Map,r.set(l,u),e.addDisposer(l,async()=>{let b=r.get(l);if(b!==void 0){r.delete(l);for(let x of b.values())await i(x)}}));let p=u.get(f);if(p!==void 0)return p.transport;let g=n.lookup(f);if(g===void 0)return;let w=Wf(f,g,async()=>{let b=e.lookup(l);if(b===void 0)throw new Error("mcp token no longer bound");if(b.session!==void 0)return b.session.sessionId;let x,C=new Promise(q=>{x=setTimeout(()=>q(void 0),dv)}),O=await Promise.race([b.sessionReady.catch(()=>{}),C]);if(x!==void 0&&clearTimeout(x),O===void 0)throw new Error("session not ready");return O.sessionId},s.buildOptions),v=new ov({sessionIdGenerator:()=>av()});return await w.connect(v),u.set(f,{server:w,transport:v}),v}async function d(l,f){let u=Lo(l);if(u===void 0){f.code(401).send({error:"missing bearer token"});return}if(e.lookup(u)===void 0){f.code(404).send({error:"unknown mcp token"});return}let g=l.params.name,h=await a(u,g);if(h===void 0){f.code(404).send({error:`unknown mcp server: ${g}`});return}f.hijack(),await h.handleRequest(l.raw,f.raw,l.body)}let c={config:{skipAuth:!0}};t.post("/mcp/:name",c,async(l,f)=>{await d(l,f)}),t.get("/mcp/:name",c,async(l,f)=>{await d(l,f)}),t.delete("/mcp/:name",c,async(l,f)=>{await d(l,f)})}async function Vf(t,e){pv(t);let n=t.daemon.tls?{key:await Bn.readFile(t.daemon.tls.key),cert:await Bn.readFile(t.daemon.tls.cert)}:void 0;await Bn.mkdir(P.home(),{recursive:!0});let{stream:s,fileStream:r}=await fv(t.daemon.logLevel),i=cv({logger:{level:t.daemon.logLevel,stream:s},https:n??null,bodyLimit:256*1024*1024});await i.register(lv,{options:{handleProtocols:Cl}}),Ua(Y=>{i.log.info(Y)}),Wa(Y=>{i.log.info(Y)});let o=await bo.load(),a=new xo,d=new ko,c=new So([new vo(e),new Io(o),d]),l=cf({validator:c});i.addHook("onRequest",async(Y,xe)=>{Y.routeOptions.config?.skipAuth||Y.url==="/acp"||Y.url?.startsWith("/acp?")||await l(Y,xe)});let f=setInterval(()=>{o.sweepExpired()},300*1e3);f.unref();let u=new ji(t,{onFetched:()=>{Zu(u,w)}});vd(Y=>i.log.info(Y));let p={info:Y=>i.log.info(Y),warn:Y=>i.log.warn(Y)},g=Y=>_n.spawn({...Y,stderrTailBytes:t.daemon.agentStderrTailBytes,logger:p});Pl(t.compressToolContent);let h=new go,w=new lo(u,g,void 0,{idleTimeoutMs:t.daemon.sessionIdleTimeoutSeconds*1e3,defaultModels:t.defaultModels,synopsisAgent:t.synopsisAgent,synopsisModel:t.synopsisModel,synopsisOnClose:t.synopsisOnClose,defaultTransformers:t.defaultTransformers,sessionHistoryMaxEntries:t.daemon.sessionHistoryMaxEntries,logger:p,npmRegistry:t.npmRegistry,extensionCommands:h,defaultCwd:t.defaultCwd}),v=new mo(dl(t),void 0,{tokenRegistry:d}),b=new ho(cl(t),void 0,{tokenRegistry:d});Rf(i,me,er(t)),Af(i,w,{agentId:t.defaultAgent,cwd:t.defaultCwd,publicHost:t.daemon.publicHost,host:t.daemon.host,port:t.daemon.port}),Cf(i,u,w,{npmRegistry:t.npmRegistry}),Tf(i,v),Ef(i,b),Pf(i,{defaultAgent:t.defaultAgent,defaultCwd:t.defaultCwd,defaultModels:{...t.defaultModels},...t.synopsisAgent!==void 0?{synopsisAgent:t.synopsisAgent}:{},...t.synopsisModel!==void 0?{synopsisModel:t.synopsisModel}:{},synopsisOnClose:t.synopsisOnClose,defaultTransformers:[...t.defaultTransformers]}),Nf(i,{store:o,rateLimiter:a});let x=new Oo,C=new Bo;qf(i,x),zf(i,x,C);let O,q=()=>{if(O!==void 0)return O;let Y=i.server.address(),xe=Y&&typeof Y=="object"?Y.port:t.daemon.port;return O=`${t.daemon.tls?"https":"http"}://${t.daemon.host}:${xe}`,O};Uf(i,{validator:c,manager:w,defaultAgent:t.defaultAgent,processRegistry:d,onExtensionVersion:(Y,xe)=>v.reportVersion(Y,xe),onTransformerVersion:(Y,xe)=>b.reportVersion(Y,xe),transformers:b,extensionCommands:h,mcpTokenRegistry:x,extensionMcp:C,getDaemonOrigin:q,registry:u}),await i.listen({host:t.daemon.host,port:t.daemon.port});let W=i.server.address(),Q=W&&typeof W=="object"?W.port:t.daemon.port;await Bn.mkdir(P.home(),{recursive:!0}),await Bn.writeFile(P.pidFile(),JSON.stringify({pid:process.pid,host:t.daemon.host,port:Q,startedAt:new Date().toISOString()})+`
|
|
271
|
+
`,{encoding:"utf8",mode:384});let N=t.daemon.tls?"https":"http",F=t.daemon.tls?"wss":"ws",U={daemonUrl:`${N}://${t.daemon.host}:${Q}`,daemonHost:t.daemon.host,daemonPort:Q,serviceToken:e,daemonWsUrl:`${F}://${t.daemon.host}:${Q}/acp`,hydraHome:P.home()};v.setContext(U),b.setContext(U),await v.start(),await b.start(),w.resurrectPendingQueues().catch(Y=>{i.log.warn(`queue replay scan failed: ${Y.message}`)});let J=t.daemon.agentSyncIntervalMinutes*60*1e3,ie=J>0?ef({registry:u,manager:w,intervalMs:J,logger:p}):void 0,be=t.daemon.sessionGcIntervalMinutes*60*1e3,te=t.daemon.sessionGcMaxAgeDays*24*60*60*1e3,X=be>0?tf({manager:w,intervalMs:be,maxAgeMs:te,logger:p}):void 0;return{app:i,manager:w,registry:u,extensions:v,transformers:b,mcpTokenRegistry:x,extensionMcp:C,processRegistry:d,shutdown:async()=>{X&&X(),ie&&ie(),clearInterval(f),await o.flush(),await v.stop(),await b.stop(),await w.closeAll(),await w.flushSynopsis(3e4),await w.shutdownSynopsis(),await w.flushMetaWrites(),await w.flushHistoryWrites(),Ua(null),Wa(null),vd(null),await i.close();try{Kf.unlinkSync(P.pidFile())}catch{}try{r.flushSync()}catch{}}}}async function fv(t){let e=await uv({file:P.logFile(),size:"10m",frequency:"daily",mkdir:!0,symlink:!0}),n=Jf.destination(2);return{stream:Jf.multistream([{stream:e,level:t},{stream:n,level:t}]),fileStream:e}}function pv(t){let e=t.daemon.host;if(!(e==="127.0.0.1"||e==="::1"||e==="localhost"||e==="[::1]")&&!t.daemon.tls)throw new Error(`Refusing to bind to non-loopback host ${e} without TLS configured.`)}ri();Lt();wo();import*as Yf from"fs";import*as or from"fs/promises";async function Nn(t,e,n){let s=yv(e),r;try{r=await or.stat(t)}catch(d){if(d.code==="ENOENT"){process.stderr.write(`${n} (${t})
|
|
272
|
+
`),process.exit(1);return}throw d}let i=await gv(t,r.size,s.tail);if(!s.follow)return;process.stdout.write(`-- following ${t} --
|
|
273
|
+
`);let o=!1,a=Yf.watch(t,()=>{o||(o=!0,setImmediate(async()=>{o=!1;try{let d=await or.stat(t);if(d.size<=i){d.size<i&&(i=d.size);return}let c=await or.open(t,"r");try{let l=Buffer.alloc(d.size-i);await c.read(l,0,l.length,i),process.stdout.write(l),i=d.size}finally{await c.close()}}catch{}}))});await new Promise(d=>{let c=()=>{a.close(),d()};process.once("SIGINT",c),process.once("SIGTERM",c)})}async function gv(t,e,n){if(n<=0||e===0)return e;let s=64*1024,r=await or.open(t,"r");try{let i=e,o="",a=0;for(;i>0&&a<=n;){let l=Math.min(s,i);i-=l;let f=Buffer.alloc(l);await r.read(f,0,l,i),o=f.toString("utf8")+o,a=(o.match(/\n/g)??[]).length}let c=o.split(`
|
|
254
274
|
`).slice(-n-1);process.stdout.write(c.join(`
|
|
255
275
|
`)),o.endsWith(`
|
|
256
276
|
`)||process.stdout.write(`
|
|
257
|
-
`)}finally{await r.close()}return e}function ar(t){let e=new Set(["--tail","-n"]),n,s=[],r=0;for(;r<t.length;){let i=t[r];if(i===void 0)break;if(i.startsWith("-")){if(s.push(i),e.has(i)&&r+1<t.length){let o=t[r+1];o!==void 0&&s.push(o),r+=2;continue}r+=1;continue}if(n===void 0){n=i,r+=1;continue}s.push(i),r+=1}return{name:n,rest:s}}function
|
|
277
|
+
`)}finally{await r.close()}return e}function ar(t){let e=new Set(["--tail","-n"]),n,s=[],r=0;for(;r<t.length;){let i=t[r];if(i===void 0)break;if(i.startsWith("-")){if(s.push(i),e.has(i)&&r+1<t.length){let o=t[r+1];o!==void 0&&s.push(o),r+=2;continue}r+=1;continue}if(n===void 0){n=i,r+=1;continue}s.push(i),r+=1}return{name:n,rest:s}}function yv(t){let e=50,n=!1,s=0;for(;s<t.length;){let r=t[s];if(r==="--tail"||r==="-n"){let i=t[s+1],o=Number.parseInt(i??"",10);(!Number.isInteger(o)||o<0)&&(process.stderr.write(`Invalid --tail value: ${i}
|
|
258
278
|
`),process.exit(2)),e=o,s+=2;continue}if(r==="--follow"||r==="-f"){n=!0,s+=1;continue}return process.stderr.write(`Unknown flag: ${r}
|
|
259
|
-
`),process.exit(2),{tail:50,follow:!1}}return{tail:e,follow:n}}async function
|
|
260
|
-
`);return}if(
|
|
279
|
+
`),process.exit(2),{tail:50,follow:!1}}return{tail:e,follow:n}}async function Xf(t={}){let e=await Z(),n=await Or();if(await si(e)){let r=await dr();process.stdout.write(`Daemon already running${r?` (pid ${r.pid})`:""}. Run \`hydra-acp daemon restart\` to restart it.
|
|
280
|
+
`);return}if(_s(t,"foreground")){process.title="hydra-daemon";let r=await Vf(e,n);process.stdout.write(`hydra-acp daemon listening on ${e.daemon.host}:${e.daemon.port}
|
|
261
281
|
`);let i=async()=>{process.stdout.write(`Shutting down...
|
|
262
282
|
`),await r.shutdown(),process.exit(0)};process.on("SIGINT",()=>{i()}),process.on("SIGTERM",()=>{i()}),process.on("SIGHUP",()=>{});return}Ho(),await Uo(e);let s=await dr();process.stdout.write(`Daemon started on ${e.daemon.host}:${e.daemon.port}`+(s?` pid=${s.pid}`:"")+`
|
|
263
|
-
`)}async function
|
|
283
|
+
`)}async function Zf(){let t=await dr();if(!t){process.stdout.write(`No running daemon found.
|
|
264
284
|
`);return}try{process.kill(t.pid,"SIGTERM"),process.stdout.write(`Sent SIGTERM to daemon pid ${t.pid}
|
|
265
285
|
`)}catch(e){process.stderr.write(`Failed to signal daemon: ${e.message}
|
|
266
|
-
`)}}async function
|
|
286
|
+
`)}}async function ep(){let t=await Z();await Or();let e=await dr();if(e&&Md(e.pid)){process.stdout.write(`Stopping daemon pid ${e.pid}...
|
|
267
287
|
`);try{process.kill(e.pid,"SIGTERM")}catch(n){process.stderr.write(`Failed to signal daemon: ${n.message}
|
|
268
|
-
`),process.exit(1)}await
|
|
288
|
+
`),process.exit(1)}await bv(e.pid)||(process.stderr.write(`Daemon pid ${e.pid} did not exit after SIGTERM; aborting restart.
|
|
269
289
|
`),process.exit(1))}else process.stdout.write(`No running daemon found; starting a fresh one.
|
|
270
290
|
`);if(Ho(),await Uo(t),await si(t)){let n=await dr();process.stdout.write(`Daemon restarted on ${t.daemon.host}:${t.daemon.port}`+(n?` pid=${n.pid}`:"")+`
|
|
271
|
-
`)}}async function
|
|
291
|
+
`)}}async function bv(t,e=5e3){let n=Date.now()+e;for(;Date.now()<n;){if(!Md(t))return!0;await wv(50)}return!1}async function tp(t){await Nn(P.currentLogFile(),t,"No daemon log file (daemon never ran?)")}async function np(){let t=await dr();if(!t){process.stdout.write(`Daemon: not running
|
|
272
292
|
`),process.stdout.write(`CLI version: ${me}
|
|
273
293
|
`);return}let e=Md(t.pid);process.stdout.write(`Daemon: ${e?"running":"stale pid file"} pid=${t.pid} host=${t.host} port=${t.port} started=${t.startedAt}
|
|
274
294
|
`);let n,s;if(e)try{let o=await Z();n=await Do(o),s=er(o)}catch{}if(!n||n.version===void 0){process.stdout.write(`CLI version: ${me}
|
|
@@ -276,92 +296,92 @@ ${Za}`:Za;await n.connection.request("session/prompt",{sessionId:d,prompt:[{type
|
|
|
276
296
|
`);return}let r=n.version===me,i=n.configDigest!==void 0&&s!==void 0&&n.configDigest===s;if(r&&i){process.stdout.write(`Version: ${me}
|
|
277
297
|
`);return}process.stdout.write(`CLI version: ${me}
|
|
278
298
|
`),process.stdout.write(`Daemon version: ${n.version}
|
|
279
|
-
`),r||process.stdout.write(
|
|
299
|
+
`),r||process.stdout.write(Qf.yellow("Version mismatch \u2014 run `hydra-acp daemon restart` to upgrade the daemon.\n")),r&&!i&&process.stdout.write(Qf.yellow("Config changed since daemon started \u2014 run `hydra-acp daemon restart` to apply.\n"))}async function dr(){try{let t=await Gf.readFile(P.pidFile(),"utf8");return JSON.parse(t)}catch(t){if(t.code==="ENOENT")return;throw t}}function Md(t){try{return process.kill(t,0),!0}catch{return!1}}Hn();Jd();Jo();jd();Ne();mt();ue();import*as Go from"fs/promises";Hn();async function Dp(){let t=await Z(),e=await pe(),n=ge(t.daemon.host,t.daemon.port,!!t.daemon.tls),s;try{let d=await fetch(`${n}/v1/extensions`,{headers:{Authorization:`Bearer ${e}`}});d.ok||(process.stderr.write(`Daemon returned HTTP ${d.status}
|
|
280
300
|
`),process.exit(1)),s=await d.json()}catch(d){process.stderr.write(`Could not reach daemon at ${n}: ${d.message}
|
|
281
301
|
`),process.exit(1);return}if(s.extensions.length===0){process.stdout.write(`No extensions configured.
|
|
282
|
-
`);return}let r=s.extensions.map(d=>({name:d.name,status:d.status.toUpperCase(),version:d.version??"-",pid:d.pid!=null?String(d.pid):"-",restarts:String(d.restartCount),started:d.startedAt?
|
|
302
|
+
`);return}let r=s.extensions.map(d=>({name:d.name,status:d.status.toUpperCase(),version:d.version??"-",pid:d.pid!=null?String(d.pid):"-",restarts:String(d.restartCount),started:d.startedAt?wI(d.startedAt):"-",log:d.logPath})),i={name:"NAME",status:"STATUS",version:"VERSION",pid:"PID",restarts:"RESTARTS",started:"STARTED",log:"LOG"},o={name:hr(i.name,r.map(d=>d.name)),status:hr(i.status,r.map(d=>d.status)),version:hr(i.version,r.map(d=>d.version)),pid:hr(i.pid,r.map(d=>d.pid)),restarts:hr(i.restarts,r.map(d=>d.restarts)),started:hr(i.started,r.map(d=>d.started))},a=d=>[d.name.padEnd(o.name),d.status.padEnd(o.status),d.version.padEnd(o.version),d.pid.padStart(o.pid),d.restarts.padStart(o.restarts),d.started.padEnd(o.started),d.log].join(" ");process.stdout.write(a(i)+`
|
|
283
303
|
`);for(let d of r)process.stdout.write(a(d)+`
|
|
284
304
|
`);for(let d of s.extensions)d.failureReason&&process.stdout.write(` \u21B3 ${d.name}: ${d.failureReason}
|
|
285
|
-
`)}async function
|
|
305
|
+
`)}async function Hp(t,e){if(!t){process.stderr.write(`Usage: hydra-acp extensions add <name> [--command CMD] [--args A,B,C] [--env K=V]... [--disabled]
|
|
286
306
|
`),process.exit(2);return}if(!/^[A-Za-z0-9._-]+$/.test(t)){process.stderr.write(`Invalid extension name '${t}': must match [A-Za-z0-9._-]+
|
|
287
|
-
`),process.exit(2);return}await Z();let n=await
|
|
288
|
-
`),process.exit(1);return}let{command:r,args:i,env:o,enabled:a}=
|
|
307
|
+
`),process.exit(2);return}await Z();let n=await jp();(!n.extensions||typeof n.extensions!="object")&&(n.extensions={});let s=n.extensions;if(s[t]){process.stderr.write(`Extension '${t}' already exists in config.
|
|
308
|
+
`),process.exit(1);return}let{command:r,args:i,env:o,enabled:a}=gI(e),d={};r.length>0&&(d.command=r),i.length>0&&(d.args=i),Object.keys(o).length>0&&(d.env=o),a||(d.enabled=!1),s[t]=d,await qp(n),process.stdout.write(`Added extension '${t}' to ${P.config()}
|
|
289
309
|
`);let c=await Z(),l=await pe(),f=ge(c.daemon.host,c.daemon.port,!!c.daemon.tls),u={name:t,...d};try{let p=await fetch(`${f}/v1/extensions`,{method:"POST",headers:{Authorization:`Bearer ${l}`,"Content-Type":"application/json"},body:JSON.stringify(u)});if(p.ok){let h=await p.json(),w=h.pid!=null?` pid=${h.pid}`:"";process.stdout.write(`${t}: ${h.status}${w}
|
|
290
310
|
`);return}let g="";try{let h=await p.json();h.error&&(g=`: ${h.error}`)}catch{}process.stderr.write(`Daemon refused to register ${t} (HTTP ${p.status}${g}). Restart the daemon to apply.
|
|
291
|
-
`)}catch{}}async function
|
|
292
|
-
`),process.exit(2);return}await Z();let e=await
|
|
293
|
-
`),process.exit(1);return}delete n[t],e.extensions=n,await
|
|
311
|
+
`)}catch{}}async function Up(t){if(!t){process.stderr.write(`Usage: hydra-acp extensions remove <name>
|
|
312
|
+
`),process.exit(2);return}await Z();let e=await jp(),n=e.extensions??{};if(!n[t]){process.stderr.write(`Extension '${t}' not found in config.
|
|
313
|
+
`),process.exit(1);return}delete n[t],e.extensions=n,await qp(e),process.stdout.write(`Removed extension '${t}' from ${P.config()}
|
|
294
314
|
`);let s=await Z(),r=await pe(),i=ge(s.daemon.host,s.daemon.port,!!s.daemon.tls);try{let o=await fetch(`${i}/v1/extensions/${encodeURIComponent(t)}`,{method:"DELETE",headers:{Authorization:`Bearer ${r}`}});if(o.status===204||o.status===404){process.stdout.write(`${t}: stopped
|
|
295
315
|
`);return}let a="";try{let d=await o.json();d.error&&(a=`: ${d.error}`)}catch{}process.stderr.write(`Daemon refused to unregister ${t} (HTTP ${o.status}${a}).
|
|
296
316
|
`)}catch(o){process.stderr.write(`Daemon not reachable (${o.message}). Config saved.
|
|
297
|
-
`)}}async function
|
|
298
|
-
`,{encoding:"utf8",mode:384})}async function
|
|
299
|
-
`),process.exit(2);return}if(t==="all"){await
|
|
317
|
+
`)}}async function jp(){let t=await Go.readFile(P.config(),"utf8");return JSON.parse(t)}async function qp(t){await Go.writeFile(P.config(),JSON.stringify(t,null,2)+`
|
|
318
|
+
`,{encoding:"utf8",mode:384})}async function Wp(t){await Kd(t,"start")}async function zp(t){await Kd(t,"stop")}async function Jp(t){await Kd(t,"restart")}async function Kd(t,e){if(!t){process.stderr.write(`Usage: hydra-acp extensions ${e} <name|all>
|
|
319
|
+
`),process.exit(2);return}if(t==="all"){await hI(e);return}let n=await Z(),s=await pe(),r=ge(n.daemon.host,n.daemon.port,!!n.daemon.tls),i;try{i=await fetch(`${r}/v1/extensions/${encodeURIComponent(t)}/${e}`,{method:"POST",headers:{Authorization:`Bearer ${s}`}})}catch(d){process.stderr.write(`Could not reach daemon at ${r}: ${d.message}
|
|
300
320
|
`),process.exit(1);return}if(!i.ok){let d="";try{let c=await i.json();c.error&&(d=`: ${c.error}`)}catch{}process.stderr.write(`HTTP ${i.status}${d}
|
|
301
321
|
`),process.exit(1);return}let o=await i.json(),a=o.pid!=null?` pid=${o.pid}`:"";process.stdout.write(`${t}: ${o.status}${a}
|
|
302
|
-
`)}async function
|
|
322
|
+
`)}async function hI(t){let e=await Z(),n=await pe(),s=ge(e.daemon.host,e.daemon.port,!!e.daemon.tls),r={Authorization:`Bearer ${n}`},i;try{let d=await fetch(`${s}/v1/extensions`,{headers:r});d.ok||(process.stderr.write(`Daemon returned HTTP ${d.status}
|
|
303
323
|
`),process.exit(1)),i=await d.json()}catch(d){process.stderr.write(`Could not reach daemon at ${s}: ${d.message}
|
|
304
324
|
`),process.exit(1);return}let o=i.extensions.filter(d=>t==="start"?d.enabled&&d.status!=="running":d.status==="running");if(o.length===0){let d=t==="start"?"no enabled extensions are stopped":"no extensions are running";process.stdout.write(`Nothing to ${t}: ${d}.
|
|
305
325
|
`);return}let a=0;for(let d of o)try{let c=await fetch(`${s}/v1/extensions/${encodeURIComponent(d.name)}/${t}`,{method:"POST",headers:r});if(!c.ok){let u="";try{let p=await c.json();p.error&&(u=`: ${p.error}`)}catch{}process.stdout.write(`${d.name}: ERROR HTTP ${c.status}${u}
|
|
306
326
|
`),a+=1;continue}let l=await c.json(),f=l.pid!=null?` pid=${l.pid}`:"";process.stdout.write(`${d.name}: ${l.status}${f}
|
|
307
327
|
`)}catch(c){process.stdout.write(`${d.name}: ERROR ${c.message}
|
|
308
|
-
`),a+=1}a>0&&process.exit(1)}async function
|
|
309
|
-
`),process.exit(2);return}let s=P.extensionLogFile(e);await
|
|
310
|
-
`),process.exit(2)),e=
|
|
328
|
+
`),a+=1}a>0&&process.exit(1)}async function Kp(t){let{name:e,rest:n}=ar(t);if(!e){process.stderr.write(`Usage: hydra-acp extensions log <name> [--tail N] [--follow]
|
|
329
|
+
`),process.exit(2);return}let s=P.extensionLogFile(e);await Nn(s,n,"No log file (extension never ran?)")}function gI(t){let e=[],n=[],s={},r=!0,i=0;for(;i<t.length;){let o=t[i];if(o==="--command"){let a=t[i+1];a===void 0&&(process.stderr.write(`--command requires a value
|
|
330
|
+
`),process.exit(2)),e=yI(a),i+=2;continue}if(o==="--args"){let a=t[i+1];a===void 0&&(process.stderr.write(`--args requires a value
|
|
311
331
|
`),process.exit(2)),n=a.split(",").filter(d=>d.length>0),i+=2;continue}if(o==="--env"){let a=t[i+1];a===void 0&&(process.stderr.write(`--env requires KEY=VALUE
|
|
312
332
|
`),process.exit(2));let d=a.indexOf("=");d<=0&&(process.stderr.write(`Invalid --env value '${a}': expected KEY=VALUE
|
|
313
333
|
`),process.exit(2)),s[a.slice(0,d)]=a.slice(d+1),i+=2;continue}if(o==="--disabled"){r=!1,i+=1;continue}return process.stderr.write(`Unknown flag: ${o}
|
|
314
|
-
`),process.exit(2),{command:[],args:[],env:{},enabled:!0}}return{command:e,args:n,env:s,enabled:r}}function
|
|
334
|
+
`),process.exit(2),{command:[],args:[],env:{},enabled:!0}}return{command:e,args:n,env:s,enabled:r}}function yI(t){return t.split(/\s+/).filter(e=>e.length>0)}function wI(t){let e=Math.max(0,Date.now()-t),n=Math.floor(e/1e3);if(n<60)return`${n}s ago`;let s=Math.floor(n/60);if(s<60)return`${s}m ago`;let r=Math.floor(s/60);return r<24?`${r}h ago`:`${Math.floor(r/24)}d ago`}function hr(t,e){let n=t.length;for(let s of e)s.length>n&&(n=s.length);return n}Ne();mt();ue();import*as Xo from"fs/promises";Hn();async function Vp(){let t=await Z(),e=await pe(),n=ge(t.daemon.host,t.daemon.port,!!t.daemon.tls),s;try{let d=await fetch(`${n}/v1/transformers`,{headers:{Authorization:`Bearer ${e}`}});d.ok||(process.stderr.write(`Daemon returned HTTP ${d.status}
|
|
315
335
|
`),process.exit(1)),s=await d.json()}catch(d){process.stderr.write(`Could not reach daemon at ${n}: ${d.message}
|
|
316
336
|
`),process.exit(1);return}if(s.transformers.length===0){process.stdout.write(`No transformers configured.
|
|
317
|
-
`);return}let r=s.transformers.map(d=>({name:d.name,status:d.status.toUpperCase(),version:d.version??"-",pid:d.pid!=null?String(d.pid):"-",restarts:String(d.restartCount),started:d.startedAt?
|
|
337
|
+
`);return}let r=s.transformers.map(d=>({name:d.name,status:d.status.toUpperCase(),version:d.version??"-",pid:d.pid!=null?String(d.pid):"-",restarts:String(d.restartCount),started:d.startedAt?SI(d.startedAt):"-",log:d.logPath})),i={name:"NAME",status:"STATUS",version:"VERSION",pid:"PID",restarts:"RESTARTS",started:"STARTED",log:"LOG"},o={name:gr(i.name,r.map(d=>d.name)),status:gr(i.status,r.map(d=>d.status)),version:gr(i.version,r.map(d=>d.version)),pid:gr(i.pid,r.map(d=>d.pid)),restarts:gr(i.restarts,r.map(d=>d.restarts)),started:gr(i.started,r.map(d=>d.started))},a=d=>[d.name.padEnd(o.name),d.status.padEnd(o.status),d.version.padEnd(o.version),d.pid.padStart(o.pid),d.restarts.padStart(o.restarts),d.started.padEnd(o.started),d.log].join(" ");process.stdout.write(a(i)+`
|
|
318
338
|
`);for(let d of r)process.stdout.write(a(d)+`
|
|
319
339
|
`);for(let d of s.transformers)d.failureReason&&process.stdout.write(` \u21B3 ${d.name}: ${d.failureReason}
|
|
320
|
-
`)}async function
|
|
340
|
+
`)}async function Yp(t,e){if(!t){process.stderr.write(`Usage: hydra-acp transformers add <name> [--command CMD] [--args A,B,C] [--env K=V]... [--disabled]
|
|
321
341
|
`),process.exit(2);return}if(!/^[A-Za-z0-9._-]+$/.test(t)){process.stderr.write(`Invalid transformer name '${t}': must match [A-Za-z0-9._-]+
|
|
322
|
-
`),process.exit(2);return}await Z();let n=await
|
|
323
|
-
`),process.exit(1);return}let{command:r,args:i,env:o,enabled:a}=
|
|
342
|
+
`),process.exit(2);return}await Z();let n=await tm();(!n.transformers||typeof n.transformers!="object")&&(n.transformers={});let s=n.transformers;if(s[t]){process.stderr.write(`Transformer '${t}' already exists in config.
|
|
343
|
+
`),process.exit(1);return}let{command:r,args:i,env:o,enabled:a}=vI(e),d={};r.length>0&&(d.command=r),i.length>0&&(d.args=i),Object.keys(o).length>0&&(d.env=o),a||(d.enabled=!1),s[t]=d,await nm(n),process.stdout.write(`Added transformer '${t}' to ${P.config()}
|
|
324
344
|
`);let c=await Z(),l=await pe(),f=ge(c.daemon.host,c.daemon.port,!!c.daemon.tls),u={name:t,...d};try{let p=await fetch(`${f}/v1/transformers`,{method:"POST",headers:{Authorization:`Bearer ${l}`,"Content-Type":"application/json"},body:JSON.stringify(u)});if(p.ok){let h=await p.json(),w=h.pid!=null?` pid=${h.pid}`:"";process.stdout.write(`${t}: ${h.status}${w}
|
|
325
345
|
`);return}let g="";try{let h=await p.json();h.error&&(g=`: ${h.error}`)}catch{}process.stderr.write(`Daemon refused to register ${t} (HTTP ${p.status}${g}). Restart the daemon to apply.
|
|
326
|
-
`)}catch{}}async function
|
|
327
|
-
`),process.exit(2);return}await Z();let e=await
|
|
328
|
-
`),process.exit(1);return}delete n[t],e.transformers=n,await
|
|
346
|
+
`)}catch{}}async function Qp(t){if(!t){process.stderr.write(`Usage: hydra-acp transformers remove <name>
|
|
347
|
+
`),process.exit(2);return}await Z();let e=await tm(),n=e.transformers??{};if(!n[t]){process.stderr.write(`Transformer '${t}' not found in config.
|
|
348
|
+
`),process.exit(1);return}delete n[t],e.transformers=n,await nm(e),process.stdout.write(`Removed transformer '${t}' from ${P.config()}
|
|
329
349
|
`);let s=await Z(),r=await pe(),i=ge(s.daemon.host,s.daemon.port,!!s.daemon.tls);try{let o=await fetch(`${i}/v1/transformers/${encodeURIComponent(t)}`,{method:"DELETE",headers:{Authorization:`Bearer ${r}`}});if(o.status===204||o.status===404){process.stdout.write(`${t}: stopped
|
|
330
350
|
`);return}let a="";try{let d=await o.json();d.error&&(a=`: ${d.error}`)}catch{}process.stderr.write(`Daemon refused to unregister ${t} (HTTP ${o.status}${a}).
|
|
331
351
|
`)}catch(o){process.stderr.write(`Daemon not reachable (${o.message}). Config saved.
|
|
332
|
-
`)}}async function
|
|
333
|
-
`),process.exit(2);return}if(t==="all"){await
|
|
352
|
+
`)}}async function Gp(t){await Vd(t,"start")}async function Xp(t){await Vd(t,"stop")}async function Zp(t){await Vd(t,"restart")}async function Vd(t,e){if(!t){process.stderr.write(`Usage: hydra-acp transformers ${e} <name|all>
|
|
353
|
+
`),process.exit(2);return}if(t==="all"){await bI(e);return}let n=await Z(),s=await pe(),r=ge(n.daemon.host,n.daemon.port,!!n.daemon.tls),i;try{i=await fetch(`${r}/v1/transformers/${encodeURIComponent(t)}/${e}`,{method:"POST",headers:{Authorization:`Bearer ${s}`}})}catch(d){process.stderr.write(`Could not reach daemon at ${r}: ${d.message}
|
|
334
354
|
`),process.exit(1);return}if(!i.ok){let d="";try{let c=await i.json();c.error&&(d=`: ${c.error}`)}catch{}process.stderr.write(`HTTP ${i.status}${d}
|
|
335
355
|
`),process.exit(1);return}let o=await i.json(),a=o.pid!=null?` pid=${o.pid}`:"";process.stdout.write(`${t}: ${o.status}${a}
|
|
336
|
-
`)}async function
|
|
356
|
+
`)}async function bI(t){let e=await Z(),n=await pe(),s=ge(e.daemon.host,e.daemon.port,!!e.daemon.tls),r={Authorization:`Bearer ${n}`},i;try{let d=await fetch(`${s}/v1/transformers`,{headers:r});d.ok||(process.stderr.write(`Daemon returned HTTP ${d.status}
|
|
337
357
|
`),process.exit(1)),i=await d.json()}catch(d){process.stderr.write(`Could not reach daemon at ${s}: ${d.message}
|
|
338
358
|
`),process.exit(1);return}let o=i.transformers.filter(d=>t==="start"?d.enabled&&d.status!=="running":d.status==="running");if(o.length===0){let d=t==="start"?"no enabled transformers are stopped":"no transformers are running";process.stdout.write(`Nothing to ${t}: ${d}.
|
|
339
359
|
`);return}let a=0;for(let d of o)try{let c=await fetch(`${s}/v1/transformers/${encodeURIComponent(d.name)}/${t}`,{method:"POST",headers:r});if(!c.ok){let u="";try{let p=await c.json();p.error&&(u=`: ${p.error}`)}catch{}process.stdout.write(`${d.name}: ERROR HTTP ${c.status}${u}
|
|
340
360
|
`),a+=1;continue}let l=await c.json(),f=l.pid!=null?` pid=${l.pid}`:"";process.stdout.write(`${d.name}: ${l.status}${f}
|
|
341
361
|
`)}catch(c){process.stdout.write(`${d.name}: ERROR ${c.message}
|
|
342
|
-
`),a+=1}a>0&&process.exit(1)}async function
|
|
343
|
-
`),process.exit(2);return}let s=P.transformerLogFile(e);await
|
|
344
|
-
`,{encoding:"utf8",mode:384})}function
|
|
345
|
-
`),process.exit(2)),e=
|
|
362
|
+
`),a+=1}a>0&&process.exit(1)}async function em(t){let{name:e,rest:n}=ar(t);if(!e){process.stderr.write(`Usage: hydra-acp transformers log <name> [--tail N] [--follow]
|
|
363
|
+
`),process.exit(2);return}let s=P.transformerLogFile(e);await Nn(s,n,"No log file (transformer never ran?)")}async function tm(){let t=await Xo.readFile(P.config(),"utf8");return JSON.parse(t)}async function nm(t){await Xo.writeFile(P.config(),JSON.stringify(t,null,2)+`
|
|
364
|
+
`,{encoding:"utf8",mode:384})}function vI(t){let e=[],n=[],s={},r=!0,i=0;for(;i<t.length;){let o=t[i];if(o==="--command"){let a=t[i+1];a===void 0&&(process.stderr.write(`--command requires a value
|
|
365
|
+
`),process.exit(2)),e=II(a),i+=2;continue}if(o==="--args"){let a=t[i+1];a===void 0&&(process.stderr.write(`--args requires a value
|
|
346
366
|
`),process.exit(2)),n=a.split(",").filter(d=>d.length>0),i+=2;continue}if(o==="--env"){let a=t[i+1];a===void 0&&(process.stderr.write(`--env requires KEY=VALUE
|
|
347
367
|
`),process.exit(2));let d=a.indexOf("=");d<=0&&(process.stderr.write(`Invalid --env value '${a}': expected KEY=VALUE
|
|
348
368
|
`),process.exit(2)),s[a.slice(0,d)]=a.slice(d+1),i+=2;continue}if(o==="--disabled"){r=!1,i+=1;continue}return process.stderr.write(`Unknown flag: ${o}
|
|
349
|
-
`),process.exit(2),{command:[],args:[],env:{},enabled:!1}}return{command:e,args:n,env:s,enabled:r}}function
|
|
369
|
+
`),process.exit(2),{command:[],args:[],env:{},enabled:!1}}return{command:e,args:n,env:s,enabled:r}}function II(t){return t.split(/\s+/).filter(e=>e.length>0)}function SI(t){let e=Math.max(0,Date.now()-t),n=Math.floor(e/1e3);if(n<60)return`${n}s ago`;let s=Math.floor(n/60);if(s<60)return`${s}m ago`;let r=Math.floor(s/60);return r<24?`${r}h ago`:`${Math.floor(r/24)}d ago`}function gr(t,e){let n=t.length;for(let s of e)s.length>n&&(n=s.length);return n}Ne();mt();ue();import*as om from"fs/promises";Hn();async function am(){let t=await Z(),e=await pe(),n=ge(t.daemon.host,t.daemon.port,!!t.daemon.tls),s;try{let c=await fetch(`${n}/v1/agents`,{headers:{Authorization:`Bearer ${e}`}});c.ok||(process.stderr.write(`Daemon returned HTTP ${c.status}
|
|
350
370
|
`),process.exit(1)),s=await c.json()}catch(c){process.stderr.write(`Could not reach daemon at ${n}: ${c.message}
|
|
351
371
|
`),process.exit(1);return}if(s.agents.length===0){process.stdout.write(`No agents in registry.
|
|
352
372
|
`);return}let r=s.agents.map(c=>({id:c.id,name:c.name,version:c.version,source:c.source??"registry",distributions:c.distributions.join(","),installed:c.installed,description:c.description??""})),i={id:"ID",name:"NAME",version:"VERSION",source:"SOURCE",distributions:"DIST",installed:"INSTALLED",description:"DESCRIPTION"},o={id:ln(i.id,r.map(c=>c.id)),name:ln(i.name,r.map(c=>c.name)),version:ln(i.version,r.map(c=>c.version)),source:ln(i.source,r.map(c=>c.source)),distributions:ln(i.distributions,r.map(c=>c.distributions)),installed:ln(i.installed,r.map(c=>c.installed))},a=c=>[c.id.padEnd(o.id),c.name.padEnd(o.name),c.version.padEnd(o.version),c.source.padEnd(o.source),c.distributions.padEnd(o.distributions),c.installed.padEnd(o.installed),c.description].join(" ");process.stdout.write(a(i)+`
|
|
353
373
|
`);for(let c of r)process.stdout.write(a(c)+`
|
|
354
|
-
`);let d=s.fetchedAt!==void 0?` (synced ${
|
|
374
|
+
`);let d=s.fetchedAt!==void 0?` (synced ${kI(Date.now()-s.fetchedAt)} ago)`:"";process.stdout.write(`
|
|
355
375
|
Registry version: ${s.version}${d}
|
|
356
|
-
`)}function
|
|
357
|
-
`),process.exit(2))}async function
|
|
376
|
+
`)}function kI(t){if(t<0)return"just now";let e=Math.floor(t/1e3);if(e<60)return"just now";let n=Math.floor(e/60);if(n<60)return`${n} minute${n===1?"":"s"}`;let s=Math.floor(n/60);if(s<24)return`${s} hour${s===1?"":"s"}`;let r=Math.floor(s/24);return`${r} day${r===1?"":"s"}`}async function Qd(t){let e=await Z();if(e.agents[t]!==void 0)return;let n=await pe(),s=ge(e.daemon.host,e.daemon.port,!!e.daemon.tls),r;try{let i=await fetch(`${s}/v1/agents`,{headers:{Authorization:`Bearer ${n}`}});if(!i.ok)return;r=(await i.json()).agents.map(a=>a.id)}catch{return}r.includes(t)||(process.stderr.write(`hydra-acp: unknown agent '${t}'. Run 'hydra-acp agent list' to see available agents.
|
|
377
|
+
`),process.exit(2))}async function dm(t){if(!t){process.stderr.write(`Usage: hydra-acp agent install <agent-id>
|
|
358
378
|
`),process.exit(2);return}let e=await Z(),n=await pe(),s=ge(e.daemon.host,e.daemon.port,!!e.daemon.tls);process.stdout.write(`Installing ${t}\u2026
|
|
359
379
|
`);let r;try{let i=await fetch(`${s}/v1/agents/${encodeURIComponent(t)}/install`,{method:"POST",headers:{Authorization:`Bearer ${n}`}});if(!i.ok){let o=`HTTP ${i.status}`;try{let a=await i.json();a.error&&(o=a.error)}catch{}process.stderr.write(`hydra agent install ${t}: ${o}
|
|
360
380
|
`),process.exit(1)}r=await i.json()}catch(i){process.stderr.write(`Could not reach daemon at ${s}: ${i.message}
|
|
361
381
|
`),process.exit(1);return}if(!r.installed){process.stdout.write(`${r.agentId} (${r.version}, ${r.distribution}): ${r.message??"nothing to install"}
|
|
362
382
|
`);return}process.stdout.write(`Installed ${r.agentId} (${r.version}, ${r.distribution})
|
|
363
383
|
`),r.command&&process.stdout.write(` \u2192 ${r.command}
|
|
364
|
-
`)}async function
|
|
384
|
+
`)}async function cm(t){if(!t){process.stderr.write(`Usage: hydra-acp agent sync <agent-id>
|
|
365
385
|
`),process.exit(2);return}let e=await Z(),n=await pe(),s=ge(e.daemon.host,e.daemon.port,!!e.daemon.tls),r;try{let c=await fetch(`${s}/v1/agents/${encodeURIComponent(t)}/sync`,{method:"POST",headers:{Authorization:`Bearer ${n}`}});if(!c.ok){let l=`HTTP ${c.status}`;try{let f=await c.json();f.error&&(l=f.error)}catch{}process.stderr.write(`hydra agent sync ${t}: ${l}
|
|
366
386
|
`),process.exit(1)}r=await c.json()}catch(c){process.stderr.write(`Could not reach daemon at ${s}: ${c.message}
|
|
367
387
|
`),process.exit(1);return}if(r.synced.length===0){process.stdout.write(`Nothing new to sync (${r.skipped} already tracked).
|
|
@@ -369,61 +389,61 @@ Registry version: ${s.version}${d}
|
|
|
369
389
|
`);for(let c of i)process.stdout.write(d(c)+`
|
|
370
390
|
`);process.stdout.write(`
|
|
371
391
|
Synced ${r.synced.length} session(s); skipped ${r.skipped} already tracked.
|
|
372
|
-
`)}async function
|
|
373
|
-
`),process.exit(2);return}let n=P.agentLogFile(t);await
|
|
392
|
+
`)}async function lm(t,e){if(!t){process.stderr.write(`Usage: hydra-acp agent log <id> [--tail N] [--follow]
|
|
393
|
+
`),process.exit(2);return}let n=P.agentLogFile(t);await Nn(n,e,"No log file (agent never ran?)")}async function um(t,e){let n=await Z(),s=await pe(),r=ge(n.daemon.host,n.daemon.port,!!n.daemon.tls);if(!t){let l=await rm(r,s)??Yd(await im());process.stdout.write(`${sm(l)}
|
|
374
394
|
`);return}let i;try{let c=await fetch(`${r}/v1/agents`,{headers:{Authorization:`Bearer ${s}`}});c.ok&&(i=(await c.json()).agents.map(f=>f.id))}catch{}if(!(n.agents[t]!==void 0)&&i!==void 0&&!i.includes(t)){process.stderr.write(`hydra agent set: '${t}' is not in the registry or config.agents. Known ids: ${i.join(", ")}
|
|
375
|
-
`),process.exit(1);return}e!==void 0?await ll(t,e):await Oi(t);let a=Yd(await
|
|
376
|
-
`),process.stdout.write(`${
|
|
377
|
-
`);let d=await
|
|
378
|
-
`))}function
|
|
395
|
+
`),process.exit(1);return}e!==void 0?await ll(t,e):await Oi(t);let a=Yd(await im());e!==void 0&&t!==a.agent&&process.stdout.write(`Default model for ${t} is now ${e}.
|
|
396
|
+
`),process.stdout.write(`${sm(a)}
|
|
397
|
+
`);let d=await rm(r,s);d!==void 0&&(d.agent===a.agent&&d.model===a.model||process.stdout.write(`Daemon still has ${fm(d)} \u2014 restart with \`hydra-acp daemon restart\` to apply.
|
|
398
|
+
`))}function sm(t){return`Default agent is ${fm(t)}`}function fm(t){return t.model!==void 0?`${t.agent} with ${t.model}`:t.agent}function Yd(t){let e=typeof t.defaultAgent=="string"?t.defaultAgent:"(unset)",s=(t.defaultModels&&typeof t.defaultModels=="object"?t.defaultModels:{})[e];return typeof s=="string"?{agent:e,model:s}:{agent:e}}async function rm(t,e){try{let n=await fetch(`${t}/v1/config`,{headers:{Authorization:`Bearer ${e}`}});if(!n.ok)return;let s=await n.json();return Yd(s)}catch{return}}async function im(){let t=await om.readFile(P.config(),"utf8");return JSON.parse(t)}async function Gd(){let t=await Z(),e=await pe(),n=ge(t.daemon.host,t.daemon.port,!!t.daemon.tls),s;try{let r=await fetch(`${n}/v1/registry/refresh`,{method:"POST",headers:{Authorization:`Bearer ${e}`}});r.ok||(process.stderr.write(`Daemon returned HTTP ${r.status}
|
|
379
399
|
`),process.exit(1)),s=await r.json()}catch(r){process.stderr.write(`Could not reach daemon at ${n}: ${r.message}
|
|
380
400
|
`),process.exit(1);return}process.stdout.write(`Refreshed registry: ${s.agentCount} agents (version ${s.version})
|
|
381
|
-
`)}async function
|
|
401
|
+
`)}async function pm(t,e){if(!t){process.stderr.write(`Usage: hydra-acp agent pin <id> [packageSpec] (omit packageSpec to clear)
|
|
382
402
|
`),process.exit(2);return}await ul(t,e),e===void 0?process.stdout.write(`Cleared version pin for ${t}.
|
|
383
403
|
`):process.stdout.write(`Pinned ${t} to ${e}.
|
|
384
|
-
`),process.stdout.write("Restart with `hydra-acp daemon restart` to apply to new sessions.\n")}async function
|
|
404
|
+
`),process.stdout.write("Restart with `hydra-acp daemon restart` to apply to new sessions.\n")}async function mm(t,e){if(!t){process.stderr.write(`Usage: hydra-acp agent add <id> [--command CMD] [--args A,B,C] [--env K=V]...
|
|
385
405
|
`),process.exit(2);return}if(!/^[A-Za-z0-9._-]+$/.test(t)){process.stderr.write(`Invalid agent id '${t}': must match [A-Za-z0-9._-]+
|
|
386
|
-
`),process.exit(2);return}let{command:n,args:s,env:r}=
|
|
387
|
-
`),process.stdout.write("Restart with `hydra-acp daemon restart` to apply to new sessions.\n")}async function
|
|
406
|
+
`),process.exit(2);return}let{command:n,args:s,env:r}=xI(e),i={};n!==void 0&&(i.command=n),s.length>0&&(i.args=s),Object.keys(r).length>0&&(i.env=r),await Ra(t,i);let o=n??`${t} (default \u2014 resolved off PATH)`;process.stdout.write(`Local agent ${t} \u2192 ${o}${s.length>0?" "+s.join(" "):""}
|
|
407
|
+
`),process.stdout.write("Restart with `hydra-acp daemon restart` to apply to new sessions.\n")}async function hm(t){if(!t){process.stderr.write(`Usage: hydra-acp agent remove <id>
|
|
388
408
|
`),process.exit(2);return}await Ra(t,void 0),process.stdout.write(`Removed local agent ${t}.
|
|
389
|
-
`),process.stdout.write("Restart with `hydra-acp daemon restart` to apply to new sessions.\n")}function
|
|
409
|
+
`),process.stdout.write("Restart with `hydra-acp daemon restart` to apply to new sessions.\n")}function xI(t){let e,n=[],s={},r=0;for(;r<t.length;){let i=t[r];if(i==="--command"){let o=t[r+1];o===void 0&&(process.stderr.write(`--command requires a value
|
|
390
410
|
`),process.exit(2)),e=o,r+=2;continue}if(i==="--args"){let o=t[r+1];o===void 0&&(process.stderr.write(`--args requires a value
|
|
391
411
|
`),process.exit(2)),n=o.split(",").filter(a=>a.length>0),r+=2;continue}if(i==="--env"){let o=t[r+1];o===void 0&&(process.stderr.write(`--env requires KEY=VALUE
|
|
392
412
|
`),process.exit(2));let a=o.indexOf("=");a<=0&&(process.stderr.write(`Invalid --env value '${o}': expected KEY=VALUE
|
|
393
413
|
`),process.exit(2)),s[o.slice(0,a)]=o.slice(a+1),r+=2;continue}return process.stderr.write(`Unknown flag: ${i}
|
|
394
414
|
`),process.exit(2),{command:void 0,args:[],env:{}}}return{command:e,args:n,env:s}}async function Xd(t){await fl(t),process.stdout.write(t?"Registry pinned to the on-disk cache. `hydra-acp agent refresh` still forces a fetch.\n":`Registry unpinned \u2014 the daemon will re-fetch per registry.ttlHours.
|
|
395
|
-
`),process.stdout.write("Restart with `hydra-acp daemon restart` to apply.\n")}function ln(t,e){let n=t.length;for(let s of e)s.length>n&&(n=s.length);return n}Ne();mt();$a();
|
|
396
|
-
`),process.exit(1))}let n=await
|
|
397
|
-
`),process.exit(2));let s=await
|
|
398
|
-
`),process.exit(1)),await
|
|
399
|
-
`)}async function
|
|
415
|
+
`),process.stdout.write("Restart with `hydra-acp daemon restart` to apply.\n")}function ln(t,e){let n=t.length;for(let s of e)s.length>n&&(n=s.length);return n}Ne();mt();$a();Hn();async function gm(t){let e=_s(t,"force");if(await Po()&&!e){let r=await Hs("Current password: ");await Mo(r)||(process.stderr.write(`Wrong password.
|
|
416
|
+
`),process.exit(1))}let n=await Hs("New password: ");n.length===0&&(process.stderr.write(`Password must not be empty.
|
|
417
|
+
`),process.exit(2));let s=await Hs("Confirm new password: ");n!==s&&(process.stderr.write(`Passwords did not match.
|
|
418
|
+
`),process.exit(1)),await Bf(n),process.stdout.write(`Password set.
|
|
419
|
+
`)}async function ym(){let t=await Z(),e=await pe(),n=ge(t.daemon.host,t.daemon.port,!!t.daemon.tls),s=await fetch(`${n}/v1/auth/sessions`,{headers:{Authorization:`Bearer ${e}`}});s.ok||(process.stderr.write(`Daemon returned HTTP ${s.status}
|
|
400
420
|
`),process.exit(1));let r=await s.json();if(r.sessions.length===0){process.stdout.write(`No active session tokens.
|
|
401
421
|
`);return}let i={id:"ID",label:"LABEL",createdAt:"CREATED",expiresAt:"EXPIRES",lastUsedAt:"LAST USED"},o=r.sessions.map(c=>({id:c.id,label:c.label??"-",createdAt:c.createdAt,expiresAt:c.expiresAt,lastUsedAt:c.lastUsedAt})),a={id:Zo(i.id,o.map(c=>c.id)),label:Zo(i.label,o.map(c=>c.label)),createdAt:Zo(i.createdAt,o.map(c=>c.createdAt)),expiresAt:Zo(i.expiresAt,o.map(c=>c.expiresAt))},d=c=>[c.id.padEnd(a.id),c.label.padEnd(a.label),c.createdAt.padEnd(a.createdAt),c.expiresAt.padEnd(a.expiresAt),c.lastUsedAt].join(" ");process.stdout.write(d(i)+`
|
|
402
422
|
`);for(let c of o)process.stdout.write(d(c)+`
|
|
403
|
-
`)}async function
|
|
423
|
+
`)}async function wm(t){t||(process.stderr.write(`Usage: hydra-acp auth revoke <id>
|
|
404
424
|
`),process.exit(2));let e=await Z(),n=await pe(),s=ge(e.daemon.host,e.daemon.port,!!e.daemon.tls),r=await fetch(`${s}/v1/auth/sessions/${t}`,{method:"DELETE",headers:{Authorization:`Bearer ${n}`}});if(r.status===204){process.stdout.write(`Revoked ${t}
|
|
405
425
|
`);return}r.status===404&&(process.stderr.write(`No session token with id ${t}
|
|
406
426
|
`),process.exit(1)),process.stderr.write(`Daemon returned HTTP ${r.status}
|
|
407
|
-
`),process.exit(1)}function Zo(t,e){let n=t.length;for(let s of e)s.length>n&&(n=s.length);return n}import*as
|
|
408
|
-
`);for(let l of c)await
|
|
409
|
-
`),r.close(),process.exit(d?1:0)}),r.onClose(()=>{a.close(),process.exit(0)}),await a.start()}function
|
|
410
|
-
`);for(let s of n){let r=typeof s.params.sessionId=="string"?s.params.sessionId:void 0;if(!r)continue;let i={sessionUpdate:"permission_resolved",outcome:{kind:"cancelled",reason:"daemon-disconnected"},resolvedBy:{clientId:"hydra-acp"}};s.toolCallId&&(i.toolCallId=s.toolCallId),await e.send({jsonrpc:"2.0",method:"session/update",params:{sessionId:r,update:i}}).catch(()=>{})}}}async function
|
|
427
|
+
`),process.exit(1)}function Zo(t,e){let n=t.length;for(let s of e)s.length>n&&(n=s.length);return n}import*as Un from"fs";Ne();Us();ri();Zd();dt();var ea=class{contexts=new Map;pending=new Map;pendingPermissions=new Map;pendingPermissionsByToolCall=new Map;lastMessageIds=new Map;observeFromClient(e){if(tc(e)){let n=this.pendingPermissions.get(e.id);n&&this.deletePendingPermission(n);return}if(ec(e)){if(e.method==="session/new"){let n=e.params??{},s=typeof n.cwd=="string"?n.cwd:"";this.pending.set(e.id,{kind:"new",data:{cwd:s}});return}if(e.method==="session/attach"){let n=e.params??{},s=typeof n.sessionId=="string"?n.sessionId:"";this.pending.set(e.id,{kind:"attach",data:{sessionId:s}});return}if(e.method==="session/load"||e.method==="session/resume"){let n=e.params??{},s=typeof n.sessionId=="string"?n.sessionId:"",r=typeof n.cwd=="string"?n.cwd:"";this.pending.set(e.id,{kind:"load",data:{sessionId:s,cwd:r}})}}}observeFromServer(e){if(!ec(e)&&!tc(e)&&"method"in e){if(e.method==="session/update"){let f=e.params??{},u=typeof f.sessionId=="string"?f.sessionId:void 0,p=typeof f.update?.messageId=="string"?f.update.messageId:void 0;u&&p&&this.lastMessageIds.set(u,p)}return}if(ec(e)){if(e.method==="session/request_permission"){let f=e.params??{},u=typeof f.sessionId=="string"?f.sessionId:void 0;if(u){let p=f.toolCall,g=p&&typeof p.toolCallId=="string"?p.toolCallId:void 0,h={requestId:e.id,sessionId:u,toolCallId:g,params:f};this.pendingPermissions.set(e.id,h),g&&this.pendingPermissionsByToolCall.set(g,h)}}return}if(!tc(e))return;if(e.error){this.pending.delete(e.id);return}let n=this.pending.get(e.id);if(!n)return;this.pending.delete(e.id);let s=e.result??{},r=typeof s.sessionId=="string"?s.sessionId:void 0;if(!r)return;let i=s._meta,o=wt(i),a=o.upstreamSessionId,d=o.agentId,c="";(n.kind==="new"||n.kind==="load")&&(c=n.data.cwd);let l=o.cwd??c;!a||!d||!l||this.contexts.set(r,{sessionId:r,upstreamSessionId:a,agentId:d,cwd:l,title:o.title,agentArgs:o.agentArgs})}list(){return[...this.contexts.values()]}forget(e){this.contexts.delete(e),this.lastMessageIds.delete(e)}lastMessageId(e){return this.lastMessageIds.get(e)}clearPending(){this.pending.clear()}takePendingPermissions(){let e=[...this.pendingPermissions.values()];return this.pendingPermissions.clear(),this.pendingPermissionsByToolCall.clear(),e}takePendingPermission(e){let n=this.pendingPermissions.get(e);return n&&this.deletePendingPermission(n),n}takePendingPermissionByToolCall(e){let n=this.pendingPermissionsByToolCall.get(e);return n&&this.deletePendingPermission(n),n}deletePendingPermission(e){this.pendingPermissions.delete(e.requestId),e.toolCallId&&this.pendingPermissionsByToolCall.delete(e.toolCallId)}};function ec(t){return"method"in t&&"id"in t&&t.id!==void 0}function tc(t){return!("method"in t)&&"id"in t}na();Lt();ue();Ni();import{writeFileSync as _I}from"fs";var FI=t=>{_I("/proc/self/comm",t)};function wr(t,e={}){if(process.title=t,(e.platform??process.platform)!=="linux")return;let s=e.writeComm??FI;try{s(e.commName??Pn())}catch{}}function br(t,e=Pn()){return t.length===0?e:`${e} ${t.join(" ")}`}async function ra(t){wr(br(process.argv.slice(2)),{commName:"hydra-shim"});let e=await Z(),n=t.target??await Wt(e);n.isLocal&&!t.target&&await ir(e);let s=new ea,r=Vi(process.stdin,process.stdout),i=n.wsUrl,o=["acp.v1",`hydra-acp-token.${n.token}`],a=new yr({url:i,subprotocols:o,onConnect:async d=>{if(d)return;s.clearPending(),await HI(s,r);let c=s.list();if(c.length!==0){process.stderr.write(`hydra-acp: reconnected; resuming ${c.length} session(s)
|
|
428
|
+
`);for(let l of c)await UI(a,l,s.lastMessageId(l.sessionId))}}});OI({opts:t,upstream:a,downstream:r,tracker:s}),a.onClose(d=>{d&&process.stderr.write(`hydra-acp: ${d.message}
|
|
429
|
+
`),r.close(),process.exit(d?1:0)}),r.onClose(()=>{a.close(),process.exit(0)}),await a.start()}function OI({opts:t,upstream:e,downstream:n,tracker:s}){e.onMessage(i=>{if(xm("daemon\u2192client",i),s.observeFromServer(i),t.dangerouslySkipPermissions===!0&&zI(i)){e.send({jsonrpc:"2.0",id:i.id,result:gs(i.params)});return}LI(i,s,n),n.send(i)});let r={name:t.name,used:!1};n.onMessage(i=>{if(xm("client\u2192daemon",i),s.observeFromClient(i),qI(i)){e.send(WI(i));return}if(jI(i)){if(t.sessionId){e.send(JI(i,t.sessionId));return}let o=i;t.agentId&&(o=sa(o,{agentId:t.agentId})),t.agentArgs&&t.agentArgs.length>0&&(o=sa(o,{agentArgs:t.agentArgs})),r.name&&!r.used&&(o=sa(o,{title:r.name}),r.used=!0),t.model&&(o=sa(o,{model:t.model})),e.send(o);return}e.send(i)})}function LI(t,e,n){let s=BI(t);if(!s)return;let r=typeof s.toolCallId=="string"?s.toolCallId:void 0;if(!r)return;let i=e.takePendingPermissionByToolCall(r);if(!i)return;let o=DI(s);n.send({jsonrpc:"2.0",id:i.requestId,result:o?{outcome:o}:null}).catch(()=>{})}function BI(t){if(!NI(t))return;let n=(t.params??{}).update;if(!(!n||typeof n!="object"||n.sessionUpdate!=="permission_resolved"))return n}function NI(t){return"method"in t&&t.method==="session/update"&&!("id"in t&&t.id!==void 0)}function DI(t){if(t.outcome&&typeof t.outcome=="object")return t.outcome;if(typeof t.chosenOptionId=="string")return{kind:"selected",optionId:t.chosenOptionId}}async function HI(t,e){let n=t.takePendingPermissions();if(n.length!==0){process.stderr.write(`hydra-acp: cancelling ${n.length} pending permission request(s)
|
|
430
|
+
`);for(let s of n){let r=typeof s.params.sessionId=="string"?s.params.sessionId:void 0;if(!r)continue;let i={sessionUpdate:"permission_resolved",outcome:{kind:"cancelled",reason:"daemon-disconnected"},resolvedBy:{clientId:"hydra-acp"}};s.toolCallId&&(i.toolCallId=s.toolCallId),await e.send({jsonrpc:"2.0",method:"session/update",params:{sessionId:r,update:i}}).catch(()=>{})}}}async function UI(t,e,n){let s={upstreamSessionId:e.upstreamSessionId,agentId:e.agentId,cwd:e.cwd};e.title!==void 0&&(s.title=e.title),e.agentArgs&&e.agentArgs.length>0&&(s.agentArgs=e.agentArgs);let r={sessionId:e.sessionId,_meta:{"hydra-acp":{resume:s}}};n?(r.historyPolicy="after_message",r.afterMessageId=n):r.historyPolicy="pending_only";let i={jsonrpc:"2.0",id:`resume-${e.sessionId}-${Date.now()}`,method:"session/attach",params:r};try{let o=await t.request(i);o.error&&process.stderr.write(`hydra-acp: replay attach for ${e.sessionId} failed: ${o.error.message}
|
|
411
431
|
`)}catch(o){process.stderr.write(`hydra-acp: failed to replay attach for ${e.sessionId}: ${o.message}
|
|
412
|
-
`)}}function
|
|
413
|
-
`;
|
|
432
|
+
`)}}function jI(t){return"method"in t&&"id"in t&&t.id!==void 0&&t.method==="session/new"}function qI(t){return"method"in t&&"id"in t&&t.id!==void 0&&t.method==="initialize"}function WI(t){let e=t.params??{},n=e.clientInfo,s=n&&typeof n=="object"&&!Array.isArray(n)?n:void 0;return(s&&typeof s.name=="string"?s.name.trim():"").length>0?t:{...t,params:{...e,clientInfo:{...s??{},name:"hydra-acp-shim",version:me}}}}function zI(t){return"method"in t&&"id"in t&&t.id!==void 0&&t.method==="session/request_permission"}function JI(t,e){return{jsonrpc:"2.0",id:t.id,method:"session/attach",params:{sessionId:e,historyPolicy:"full"}}}var KI=25*1024*1024,km=!1,ys=null;function xm(t,e){if(process.env.HYDRA_SHIM_WIRE_LOG){if(!km){km=!0;try{ys=P.shimWireLogFile(),Un.mkdirSync(P.home(),{recursive:!0});let n=Un.statSync(ys,{throwIfNoEntry:!1});n&&n.size>KI&&Un.renameSync(ys,`${ys}.1`)}catch{ys=null}}if(ys)try{let n=JSON.stringify({t:new Date().toISOString(),pid:process.pid,dir:t,msg:e})+`
|
|
433
|
+
`;Un.appendFile(ys,n,()=>{})}catch{}}}function sa(t,e){let n=t.params??{},s=n._meta??{},r=s["hydra-acp"]??{};return{...t,params:{...n,_meta:{...s,"hydra-acp":{...r,...e}}}}}Nr();$o();Ne();Us();ri();ms();dt();Lt();na();import{mkdtempSync as rS,rmSync as iS}from"fs";import{tmpdir as oS}from"os";import{join as aS}from"path";import{WebSocket as dS}from"ws";function Am(t){let e="",n=!1,s=!1,r=!1,i=()=>{if(e.length===0)return;let a=e;e="",t.onChunk(a)},o=()=>{s||(s=!0,n=!1,t.scheduleFlushCheck(()=>{if(s=!1,n){o();return}i()}))};return{feed(a){r||a.length===0||(e+=a,s?n=!0:o())},eof(){r||(r=!0,i())}}}di();import VI from"chalk";import YI from"strip-ansi";var ia=new VI.Instance({level:3});function Cm(t,e){if(t.length===0)return"";let n=mr(t);if(n.length===0)return"";let s=[];for(let i of n)s.push(QI(i,e));let r=s.join(`
|
|
414
434
|
`);return r.endsWith(`
|
|
415
435
|
`)||(r+=`
|
|
416
|
-
`),r}function
|
|
417
|
-
`),process.exit(2);return}if(!t.sessionId&&t.cwd===void 0&&process.stdin.isTTY!==!0){let d=
|
|
436
|
+
`),r}function QI(t,e){let n=nS(t.body,e);return e==="ansi"?n=sS(n,t.bodyStyle):n=YI(n),n}var GI="\x1B[1m",XI="\x1B[96m",ZI="\x1B[93m",eS="\x1B[0m",tS="\0";function nS(t,e){let n=t.replace(/\^\^/g,tS);return e==="ansi"&&(n=n.replace(/\^\+/g,GI).replace(/\^C/g,XI).replace(/\^Y/g,ZI).replace(/\^:/g,eS)),n=n.replace(/\^[+\-:CcKY]/g,""),n=n.replace(/\x00/g,"^"),n}function sS(t,e){if(t.length===0||e===void 0)return t;switch(e){case"heading-1":return ia.bold.yellowBright(t);case"heading-2":return ia.bold.cyanBright(t);case"heading-3":return ia.bold(t);case"dim":return ia.dim(t);default:return t}}var cS=1*1024*1024,Rm="mcp__hydra-acp-stdin__";function Tm(t,e){return{sessionId:t,prompt:e,_meta:{[Ct]:{ancillary:!0}}}}function lS(t){if(t)for(let e of t.split(/\r?\n/)){let n=e.trim();if(n)return n.length>80?`${n.slice(0,80)}\u2026`:n}}function uS(t){if(!t||typeof t!="object")return!1;let e=t.toolCall;if(!e||typeof e!="object")return!1;let n=e.title;if(typeof n=="string"&&n.startsWith(Rm))return!0;let s=e.toolName;return!!(typeof s=="string"&&s.startsWith(Rm))}async function Em(t){if(wr(br(process.argv.slice(2))),process.stdin.isTTY&&!t.prompt&&!t.sessionId){process.stderr.write(`hydra-acp cat: nothing to send. Pipe input on stdin, pass -p <text>, or attach to an existing session with --session.
|
|
437
|
+
`),process.exit(2);return}if(!t.sessionId&&t.cwd===void 0&&process.stdin.isTTY!==!0){let d=rS(aS(oS(),"hydra-cat-"));t.cwd=d,t.detach||process.on("exit",()=>{try{iS(d,{recursive:!0,force:!0})}catch{}})}let e=await Z(),n=t.target??await Wt(e);n.isLocal&&!t.target&&await ir(e);let s=["acp.v1",`hydra-acp-token.${n.token}`],r=await yS(n.wsUrl,s),i=rr(r),o=new Kt(i),a=await pS({conn:o,opts:t,stdin:process.stdin,stdinIsTty:process.stdin.isTTY===!0,stdoutIsTty:process.stdout.isTTY===!0,stdout:d=>process.stdout.write(d),stderr:d=>{process.stderr.write(d)},streamClient:fS(n.baseUrl,n.token)});process.exit(a.exitCode)}function fS(t,e){let n={"Content-Type":"application/json",Authorization:`Bearer ${e}`},s=(r,i)=>`${t}/v1/sessions/${encodeURIComponent(r)}/stdin${i}`;return{async open(r,i){let o=await fetch(s(r,"/open"),{method:"POST",headers:n,body:JSON.stringify(i)});if(!o.ok)throw new Error(`stdin/open HTTP ${o.status}`);return await o.json()},async write(r,i,o){let a=await fetch(s(r,""),{method:"POST",headers:n,body:JSON.stringify({chunk:i,eof:o})});if(!a.ok)throw new Error(`stdin write HTTP ${a.status}`)}}}async function pS(t){let{conn:e,opts:n,stdin:s,stdinIsTty:r,stdoutIsTty:i,stdout:o,stderr:a}=t,d=i?"ansi":"plain",c=n.raw===!0,l=!r&&n.sessionId===void 0&&n.follow!==!0;e.setDefaultHandler(async()=>({error:{code:-32601,message:"method not implemented"}})),e.onRequest("session/request_permission",async X=>n.dangerouslySkipPermissions?gs(X):uS(X)?gs(X):vm(X));try{await e.request("initialize",{protocolVersion:yt,clientCapabilities:{fs:{readTextFile:!1,writeTextFile:!1},terminal:!1},clientInfo:{name:cs,version:me}})}catch{}let f=await gS(e,n,l),u=!1,p=!0,g="",h=0,w=X=>{X.length!==0&&(o(X),p=X.charCodeAt(X.length-1)===10,u=!0)},v=()=>{if(c||g.length===0)return;let X=Cm(g,d);if(g="",X.length===0)return;let Ie=h>0?`
|
|
418
438
|
`:"";w(Ie+X),h+=1},b=()=>{v(),u&&!p&&w(`
|
|
419
|
-
`),u=!1};e.onNotification("session/update",X=>{let Ie=X?.update,Y=
|
|
439
|
+
`),u=!1};e.onNotification("session/update",X=>{let Ie=X?.update,Y=ps(Ie,{cwd:n.cwd});if(Y){if(Y.kind==="agent-text"){c?w(Y.text):g+=Y.text;return}if(Y.kind==="turn-complete"){b();return}switch(Y.kind){case"agent-thought":case"tool-call":case"tool-call-update":case"exit-plan-mode":case"plan":case"mode-changed":case"user-text":v();return;default:return}}});let x=!1,C=async X=>{let Ie=[];if(n.prompt&&!x&&Ie.push({type:"text",text:n.prompt}),X.length>0&&Ie.push({type:"text",text:X}),Ie.length!==0){try{await e.request("session/prompt",Tm(f,Ie)),x=!0}catch(Y){a(`hydra-acp cat: prompt failed: ${Y.message}
|
|
420
440
|
`);return}b()}},O=0,q,W=new Promise(X=>{q=X}),Q=!1,N=async X=>{Q||(Q=!0,b(),n.detach||e.request("session/detach",{sessionId:f}).catch(()=>{}),await e.close().catch(()=>{}),q({exitCode:X}))};e.onClose(X=>{X&&(a(`hydra-acp cat: ${X.message}
|
|
421
|
-
`),O=1),Q||(Q=!0,b(),q({exitCode:O}))});let F=[],U=!1,J=!1,ie=async()=>{if(!U){U=!0;try{for(;F.length>0;){let X=F.shift();if(X===void 0)break;await C(X)}}finally{U=!1,J&&F.length===0&&await N(O)}}};if(r&&!n.sessionId)return n.prompt&&await C(""),await N(0),W;if(l)return typeof s.setEncoding=="function"&&s.setEncoding("utf8"),
|
|
441
|
+
`),O=1),Q||(Q=!0,b(),q({exitCode:O}))});let F=[],U=!1,J=!1,ie=async()=>{if(!U){U=!0;try{for(;F.length>0;){let X=F.shift();if(X===void 0)break;await C(X)}}finally{U=!1,J&&F.length===0&&await N(O)}}};if(r&&!n.sessionId)return n.prompt&&await C(""),await N(0),W;if(l)return typeof s.setEncoding=="function"&&s.setEncoding("utf8"),mS({conn:e,streamClient:t.streamClient,sessionId:f,opts:n,stdin:s,stderr:a,sendInline:C,onEof:()=>{J=!0,!U&&F.length===0&&N(O)},onError:X=>{a(`hydra-acp cat: stdin error: ${X.message}
|
|
422
442
|
`),O=1,J=!0,!U&&F.length===0&&N(O)},onPromptFailed:X=>{a(`hydra-acp cat: ${X.message}
|
|
423
|
-
`),O=1,J=!0,!U&&F.length===0&&N(O)}}),W;if(typeof s.setEncoding=="function"&&s.setEncoding("utf8"),n.follow===!0||r&&!!n.sessionId){let X=
|
|
443
|
+
`),O=1,J=!0,!U&&F.length===0&&N(O)}}),W;if(typeof s.setEncoding=="function"&&s.setEncoding("utf8"),n.follow===!0||r&&!!n.sessionId){let X=Am({scheduleFlushCheck:Ie=>{let Y=setImmediate(Ie);return()=>clearImmediate(Y)},onChunk:Ie=>{F.push(Ie),ie()}});return s.on("data",Ie=>{X.feed(typeof Ie=="string"?Ie:Ie.toString("utf8"))}),s.on("end",()=>{X.eof(),J=!0,!U&&F.length===0&&N(O)}),s.on("error",Ie=>{a(`hydra-acp cat: stdin error: ${Ie.message}
|
|
424
444
|
`),O=1,J=!0,!U&&F.length===0&&N(O)}),W}let te="";return s.on("data",X=>{te+=typeof X=="string"?X:X.toString("utf8")}),s.on("end",()=>{J=!0,te.length>0&&F.push(te),ie()}),s.on("error",X=>{a(`hydra-acp cat: stdin error: ${X.message}
|
|
425
|
-
`),O=1,J=!0,!U&&F.length===0&&N(O)}),W}function
|
|
426
|
-
`)})},g=async()=>{c="inline";let w=l.toString("utf8");l=Buffer.alloc(0);try{await a(w)}catch(v){t.onPromptFailed(v);return}t.onEof()},h=async()=>{c="file";let w;try{let x={mode:"memory"};r.streamBufferBytes!==void 0&&(x.capacityBytes=r.streamBufferBytes),w=await n.open(s,x)}catch(x){t.onPromptFailed(new Error(`stdin/open failed: ${x.message}`));return}l.length>0&&(p(l,!1),l=Buffer.alloc(0)),await u.catch(()=>{});let v=
|
|
445
|
+
`),O=1,J=!0,!U&&F.length===0&&N(O)}),W}function mS(t){let{conn:e,streamClient:n,sessionId:s,opts:r,stdin:i,stderr:o,sendInline:a}=t,d=r.streamThreshold??cS,c="undecided",l=Buffer.alloc(0),f=!1,u=Promise.resolve(),p=(w,v)=>{let b=w.toString("base64");u=u.then(()=>n.write(s,b,v)).catch(x=>{o(`hydra-acp cat: stdin write failed: ${x.message}
|
|
446
|
+
`)})},g=async()=>{c="inline";let w=l.toString("utf8");l=Buffer.alloc(0);try{await a(w)}catch(v){t.onPromptFailed(v);return}t.onEof()},h=async()=>{c="file";let w;try{let x={mode:"memory"};r.streamBufferBytes!==void 0&&(x.capacityBytes=r.streamBufferBytes),w=await n.open(s,x)}catch(x){t.onPromptFailed(new Error(`stdin/open failed: ${x.message}`));return}l.length>0&&(p(l,!1),l=Buffer.alloc(0)),await u.catch(()=>{});let v=hS(r.prompt,w.capacityBytes);e.request("session/prompt",Tm(s,[{type:"text",text:v}])).catch(x=>{t.onPromptFailed(new Error(`prompt failed: ${x.message}`))}).then(()=>{f||p(Buffer.alloc(0),!0),t.onEof()})};i.on("data",w=>{let v=typeof w=="string"?Buffer.from(w,"utf8"):w;if(c==="undecided"){l=Buffer.concat([l,v]),l.length>d&&h();return}if(c==="file"){p(v,!1);return}l=Buffer.concat([l,v])}),i.on("end",()=>{if(f=!0,c==="undecided"){g();return}c==="file"&&p(Buffer.alloc(0),!0)}),i.on("error",t.onError)}function hS(t,e){let s=`The user has piped data into this session. The bytes are NOT in your prompt; they live in the \`hydra-acp-stdin\` MCP server and you read them via its tools:
|
|
427
447
|
- \`info()\` \u2014 current writeCursor / oldestAvailable / capacity / closed. Cheap; call first to see how much data is there.
|
|
428
448
|
- \`grep({pattern, regex?, case_insensitive?, context_before?, context_after?, cursor?})\` \u2014 server-side line filter; returns matching lines as decoded strings (not base64). Prefer this for "find lines that mention X" questions on multi-MB inputs.
|
|
429
449
|
- \`head({bytes})\` \u2014 first N bytes (good for headers / preamble / file signatures).
|
|
@@ -438,29 +458,29 @@ Use those tools NOW to answer the user's question \u2014 do not ask whether to c
|
|
|
438
458
|
User's question:
|
|
439
459
|
${t}`:`${s}
|
|
440
460
|
|
|
441
|
-
Use those tools to inspect the piped input and report what's there. Start with \`info()\` to see the size, then \`head\` and/or \`tail\` to look at the bytes.`}async function
|
|
442
|
-
`),process.exit(1)),typeof n.status=="number"&&process.exit(n.status),n.signal&&process.kill(process.pid,n.signal),process.exit(1)}function
|
|
443
|
-
`))}async function
|
|
461
|
+
Use those tools to inspect the piped input and report what's there. Start with \`info()\` to see the size, then \`head\` and/or \`tail\` to look at the bytes.`}async function gS(t,e,n){if(e.sessionId)return(await t.request("session/attach",{sessionId:e.sessionId,historyPolicy:"pending_only",clientInfo:{name:cs,version:me}})).sessionId;let s={};if(e.name)s.title=e.name;else{let a=lS(e.prompt);a&&(s.title=a)}e.model&&(s.model=e.model),n&&(s.mcpStdin=!0);let i={cwd:e.cwd??process.cwd()};e.agentId&&(s.agentId=e.agentId),Object.keys(s).length>0&&(i._meta={[Ct]:s});let o=await t.request("session/new",i);return wt(o._meta),o.sessionId}async function yS(t,e){return new Promise((n,s)=>{let r=new dS(t,e),i=()=>{r.off("error",o),n(r)},o=a=>{r.off("open",i),s(a)};r.once("open",i),r.once("error",o)})}import{spawnSync as wS}from"child_process";import{accessSync as bS,constants as vS,statSync as IS}from"fs";import{delimiter as SS,join as kS}from"path";var xS=new Set(["agent","agents","auth","cat","daemon","extension","extensions","init","launch","registry","session","sessions","shim","transformer","transformers","tui"]);function AS(t){return xS.has(t)}function CS(t){for(let e of t)if(e!==void 0&&!e.startsWith("-"))return e}function RS(t){let e=[],n=!1;for(let s of t){if(!n&&s!==void 0&&!s.startsWith("-")){n=!0;continue}s!==void 0&&e.push(s)}return e}function TS(t){try{if(!IS(t).isFile())return!1}catch{return!1}if(process.platform==="win32")return!0;try{return bS(t,vS.X_OK),!0}catch{return!1}}function ES(t,e=process.env){let n=e.PATH??e.Path??"";if(n.length===0)return;let s=n.split(SS).filter(o=>o.length>0),r=`hydra-acp-${t}`,i=process.platform==="win32"?(e.PATHEXT??".COM;.EXE;.BAT;.CMD").split(";"):[""];for(let o of s)for(let a of i){let d=kS(o,r+a);if(TS(d))return d}}function PS(t,e){let n=wS(t,e,{stdio:"inherit",env:process.env});n.error&&(process.stderr.write(`hydra-acp: failed to exec ${t}: ${n.error.message}
|
|
462
|
+
`),process.exit(1)),typeof n.status=="number"&&process.exit(n.status),n.signal&&process.kill(process.pid,n.signal),process.exit(1)}function Pm(t){let e=CS(t);if(e===void 0||AS(e))return!1;let n=ES(e);if(n===void 0)return!1;PS(n,RS(t))}nc();var vs=!1,Bh=!1;function Nh(t){!t||Bh||(Bh=!0,process.stderr.write(`hydra-acp: --dangerously-skip-permissions is set \u2014 all tool permission requests will be auto-approved.
|
|
463
|
+
`))}async function cx(){let t=process.argv.slice(2),e=t.indexOf("launch");if(e!==-1){let w=t.slice(0,e),v=t.slice(e+1),b=v[0],x=v.slice(1),{flags:C}=xa(w);if(Hh(C),C.reattach===!0){process.stderr.write(`hydra-acp launch: --reattach is not valid here. Pass --session <id-or-url> to attach to a specific session.
|
|
444
464
|
`),process.exit(2);return}let O=b??Ve(C,"agent");if(!O){process.stderr.write(`Usage: hydra-acp launch <agent> [agent-args...]
|
|
445
|
-
`),process.exit(2);return}let q=await
|
|
446
|
-
`);return}if(s.help===!0){Oc();return}let r=_c(t)!==void 0||typeof s.prompt=="string",i=n[0],o=i!==void 0&&!i.startsWith("-")?i:r?"cat":i,a=Ve(s,"name"),d=Ve(s,"agent"),c=Ve(s,"model"),l=s["dangerously-skip-permissions"]===!0;
|
|
447
|
-
`),process.exit(2));let g=p?.sessionId,h=p?.fromUrl?p.target:void 0;if(!o){if(process.stdout.isTTY){
|
|
448
|
-
`),process.exit(2);return}case"session":case"sessions":{let w=n[1];if(w===void 0||w==="list"){let v=Ve(s,"columns"),b;if(v!==void 0)try{b=
|
|
449
|
-
`),process.exit(2);return}await
|
|
465
|
+
`),process.exit(2);return}let q=await Uh(Oa(C),{allowPrompt:!1}),W=Ve(C,"name"),Q=Ve(C,"model");vs=!0;let N=C["dangerously-skip-permissions"]===!0;Nh(N);let F={agentId:O,agentArgs:x,name:W,model:Q,dangerouslySkipPermissions:N};q?.sessionId!==void 0&&(F.sessionId=q.sessionId),q?.target!==void 0&&q.fromUrl&&(F.target=q.target),await ra(F);return}_c(t)===void 0&&!t.some(w=>w==="--prompt"||w.startsWith("--prompt="))&&Pm(t);let{positional:n,flags:s}=xa(t);if(Hh(s),s.version===!0||n[0]==="--version"){process.stdout.write(`hydra-acp ${lx()}
|
|
466
|
+
`);return}if(s.help===!0){Oc();return}let r=_c(t)!==void 0||typeof s.prompt=="string",i=n[0],o=i!==void 0&&!i.startsWith("-")?i:r?"cat":i,a=Ve(s,"name"),d=Ve(s,"agent"),c=Ve(s,"model"),l=s["dangerously-skip-permissions"]===!0;Nh(l);let f=Oa(s),u=o==="tui"||o===void 0&&process.stdout.isTTY,p=await Uh(f,{allowPrompt:u});p!==void 0&&p.sessionId!==void 0&&s.reattach===!0&&(process.stderr.write(`hydra-acp: --session <id> and --reattach are mutually exclusive. Use one or the other.
|
|
467
|
+
`),process.exit(2));let g=p?.sessionId,h=p?.fromUrl?p.target:void 0;if(!o){if(process.stdout.isTTY){vs=!0,await Dh(s,{sessionId:g,agentId:d,name:a,model:c,target:h,dangerouslySkipPermissions:l});return}vs=!0;let w={name:a,model:c,agentId:d,dangerouslySkipPermissions:l};g!==void 0&&(w.sessionId=g),h!==void 0&&(w.target=h),await ra(w);return}switch(o){case"shim":{vs=!0;let w={name:a,model:c,agentId:d,dangerouslySkipPermissions:l};g!==void 0&&(w.sessionId=g),h!==void 0&&(w.target=h),await ra(w);return}case"cat":{let w=_c(t),v=typeof s.prompt=="string"?s.prompt:void 0,b=w??v,x=Ve(s,"cwd"),C={prompt:b,sessionId:g,name:a,model:c,agentId:d,detach:s.detach===!0,follow:s.follow===!0,raw:s.raw===!0,dangerouslySkipPermissions:l};x!==void 0&&(C.cwd=x),h!==void 0&&(C.target=h);let O=Fc(s,"stream-threshold");O!==void 0&&(C.streamThreshold=O);let q=Fc(s,"stream-bytes");q!==void 0&&(C.streamBufferBytes=q),d!==void 0&&await Qd(d),vs=!0,await Em(C);return}case"init":await xl(s);return;case"daemon":{let w=t.indexOf("daemon"),v=t.slice(w+1),b=v[0];if(b===void 0||b==="status"){await np();return}if(b==="start"){await Xf(s);return}if(b==="stop"){await Zf();return}if(b==="restart"){await ep();return}if(b==="log"||b==="logs"){await tp(v.slice(1));return}process.stderr.write(`Unknown daemon subcommand: ${b}
|
|
468
|
+
`),process.exit(2);return}case"session":case"sessions":{let w=n[1];if(w===void 0||w==="list"){let v=Ve(s,"columns"),b;if(v!==void 0)try{b=hp(v)}catch(x){process.stderr.write(`${x.message}
|
|
469
|
+
`),process.exit(2);return}await yp({all:s.all===!0,json:s.json===!0,host:typeof s.host=="string"?s.host:void 0,includeNonInteractive:s["include-non-interactive"]===!0,columns:b});return}if(w==="info"){await Np(n[2],{verbose:s.verbose===!0,json:s.json===!0,diff:s.diff===!0,fold:s.fold===!0,noColor:s["no-color"]===!0,noPager:s["no-pager"]===!0});return}if(w==="diff"){await Bp(n[2],{json:s.json===!0,noColor:s["no-color"]===!0,noPager:s["no-pager"]===!0,fold:s.fold===!0});return}if(w==="kill"){await wp(n[2]);return}if(w==="remove"){await bp(n[2]);return}if(w==="collect"){let v=Ve(s,"max-age-days"),b=Ve(s,"limit"),x={json:s.json===!0,keepUndecided:s["keep-undecided"]===!0};if(v!==void 0){let C=Number(v);if(!Number.isFinite(C)||C<0){process.stderr.write(`--max-age-days must be a non-negative number
|
|
450
470
|
`),process.exit(2);return}x.maxAgeDays=C}if(b!==void 0){let C=Number(b);if(!Number.isFinite(C)||C<=0){process.stderr.write(`--limit must be a positive number
|
|
451
|
-
`),process.exit(2);return}x.limit=C}await
|
|
452
|
-
`),process.exit(2);return}case"extension":case"extensions":{let w=t.indexOf(o),v=t.slice(w+1),b=v[0],x=v[1],C=v.slice(2);if(b===void 0||b==="list"){await
|
|
453
|
-
`),process.exit(2);return}case"transformer":case"transformers":{let w=t.indexOf(o),v=t.slice(w+1),b=v[0],x=v[1],C=v.slice(2);if(b===void 0||b==="list"){await
|
|
454
|
-
`),process.exit(2);return}case"agent":case"agents":{let w=n[1];if(w===void 0||w==="list"){await
|
|
471
|
+
`),process.exit(2);return}x.limit=C}await vp(x);return}if(w==="export"){let v=Ve(s,"out"),b=Ve(s,"tools");await Ip(n[2],v,b);return}if(w==="transcript"){let v=Ve(s,"out");await Sp(n[2],v);return}if(w==="import"){let v=Ve(s,"cwd");await kp(n[2],{replace:s.replace===!0,info:s.info===!0,...v!==void 0?{cwd:v}:{}});return}if(w==="share"){let v=Ve(s,"host"),b=Ve(s,"cwd");await xp(n[2],{...v!==void 0?{host:v}:{},...b!==void 0?{cwd:b}:{}});return}process.stderr.write(`Unknown session subcommand: ${w}
|
|
472
|
+
`),process.exit(2);return}case"extension":case"extensions":{let w=t.indexOf(o),v=t.slice(w+1),b=v[0],x=v[1],C=v.slice(2);if(b===void 0||b==="list"){await Dp();return}if(b==="add"){await Hp(x,C);return}if(b==="remove"){await Up(x);return}if(b==="start"){await Wp(x);return}if(b==="stop"){await zp(x);return}if(b==="restart"){await Jp(x);return}if(b==="log"||b==="logs"){await Kp(v.slice(1));return}process.stderr.write(`Unknown extension subcommand: ${b}
|
|
473
|
+
`),process.exit(2);return}case"transformer":case"transformers":{let w=t.indexOf(o),v=t.slice(w+1),b=v[0],x=v[1],C=v.slice(2);if(b===void 0||b==="list"){await Vp();return}if(b==="add"){await Yp(x,C);return}if(b==="remove"){await Qp(x);return}if(b==="start"){await Gp(x);return}if(b==="stop"){await Xp(x);return}if(b==="restart"){await Zp(x);return}if(b==="log"||b==="logs"){await em(v.slice(1));return}process.stderr.write(`Unknown transformer subcommand: ${b}
|
|
474
|
+
`),process.exit(2);return}case"agent":case"agents":{let w=n[1];if(w===void 0||w==="list"){await am();return}if(w==="refresh"){await Gd();return}if(w==="install"){await dm(n[2]);return}if(w==="sync"){await cm(n[2]);return}if(w==="set"){await um(n[2],n[3]);return}if(w==="pin"){await pm(n[2],n[3]);return}if(w==="add"){let v=t.indexOf(o),b=t.slice(v+1);await mm(b[1],b.slice(2));return}if(w==="remove"){await hm(n[2]);return}if(w==="log"||w==="logs"){let v=t.indexOf(o),b=t.slice(v+2),{name:x,rest:C}=ar(b);await lm(x,C);return}process.stderr.write(`Unknown agent subcommand: ${w}
|
|
455
475
|
`),process.exit(2);return}case"registry":{let w=n[1];if(w==="refresh"){await Gd();return}if(w==="pin"){await Xd(!0);return}if(w==="unpin"){await Xd(!1);return}process.stderr.write(`Unknown registry subcommand: ${w}
|
|
456
|
-
`),process.exit(2);return}case"auth":{let w=n[1];if(w==="password"){let v=n[2];if(v===void 0||v==="set"){await
|
|
457
|
-
`),process.exit(2);return}if(w===void 0||w==="list"){await
|
|
458
|
-
`),process.exit(2);return}case"tui":
|
|
459
|
-
`),Oc(),process.exit(2)}}async function
|
|
460
|
-
`),process.exit(2)),a.drip=!0;let d=Fc(t,"drip-speed");d!==void 0&&d>0&&(a.dripSpeed=d)}await o(a)}function Fc(t,e){let n=t[e];if(n!==void 0){if(typeof n=="number"&&Number.isFinite(n))return n;if(typeof n=="string"){let s=Number(n);if(Number.isFinite(s))return s}}}function
|
|
476
|
+
`),process.exit(2);return}case"auth":{let w=n[1];if(w==="password"){let v=n[2];if(v===void 0||v==="set"){await gm(s);return}process.stderr.write(`Unknown auth password action: ${v}
|
|
477
|
+
`),process.exit(2);return}if(w===void 0||w==="list"){await ym();return}if(w==="revoke"){await wm(n[2]);return}process.stderr.write(`Unknown auth subcommand: ${w}
|
|
478
|
+
`),process.exit(2);return}case"tui":vs=!0,await Dh(s,{sessionId:g,agentId:d,name:a,model:c,target:h,dangerouslySkipPermissions:l});return;default:process.stderr.write(`Unknown command: ${o}
|
|
479
|
+
`),Oc(),process.exit(2)}}async function Dh(t,e){let n=Ve(t,"cwd"),s=t.reattach===!0,r=t.new===!0,i=t.readonly===!0;i&&e.sessionId===void 0&&(process.stderr.write("hydra-acp: --readonly requires a session id. Pass --session <id-or-url> --readonly, or open the picker and press `v` on a session.\n"),process.exit(2)),e.agentId!==void 0&&await Qd(e.agentId),wr(br(process.argv.slice(2)));let{runTui:o}=await Promise.resolve().then(()=>(Lh(),Oh)),a={resume:s,forceNew:r,readonly:i};if(e.sessionId!==void 0&&(a.sessionId=e.sessionId),e.agentId!==void 0&&(a.agentId=e.agentId),n!==void 0&&(a.cwd=n),e.name!==void 0&&(a.name=e.name),e.model!==void 0&&(a.model=e.model),e.target!==void 0&&(a.target=e.target),e.dangerouslySkipPermissions===!0&&(a.dangerouslySkipPermissions=!0),t.drip===!0){e.sessionId===void 0&&(process.stderr.write(`hydra-acp: --drip requires a session id. Pass --session <id-or-url> --drip.
|
|
480
|
+
`),process.exit(2)),a.drip=!0;let d=Fc(t,"drip-speed");d!==void 0&&d>0&&(a.dripSpeed=d)}await o(a)}function Fc(t,e){let n=t[e];if(n!==void 0){if(typeof n=="number"&&Number.isFinite(n))return n;if(typeof n=="string"){let s=Number(n);if(Number.isFinite(s))return s}}}function Hh(t){let e=tl(t);e!==void 0&&(process.stderr.write(`hydra-acp: unknown flag: --${e}
|
|
461
481
|
|
|
462
|
-
`),Oc(),process.exit(2))}function _c(t){for(let e=0;e<t.length;e+=1){let n=t[e];if(n!==void 0){if(n==="-p")return t[e+1];if(n.startsWith("-p")&&!n.startsWith("--"))return n.slice(2)}}}async function
|
|
463
|
-
`),process.exit(1)}}function cx(){try{let t=ox(ix(import.meta.url));return JSON.parse(rx(ax(t,"../package.json"),"utf8")).version??"unknown"}catch{return"unknown"}}function Oc(){process.stdout.write(["hydra-acp \u2014 multi-client ACP session daemon","","Usage:"," hydra-acp [--session <id-or-url>] [--reattach] [opts]"," Auto: TUI when stdout is a TTY, shim otherwise (the editor-spawned case)."," With -p / --prompt and no subcommand, auto-dispatch to cat."," hydra-acp tui [same flags] Force TUI explicitly."," hydra-acp shim [same flags] Force shim explicitly (non-interactive; password prompts not allowed)."," hydra-acp cat [-p <prompt>] [--session <id-or-url>] [--detach] [--raw] [--agent <id>] [--model <id>] [--name <label>]"," Pipe-friendly headless mode. Reads stdin and sends it"," as a prompt to a fresh session, streams the agent's"," response to stdout, exits when stdin closes. A bounded",' input (e.g. `cat file.log | hydra cat -p "..."`) goes in'," as one turn; a streaming input (e.g. `tail -f`) is"," chunked by the natural pauses in the writer. -p is an"," optional standing instruction prepended to every chunk;"," if stdin already contains the question, -p is not needed."," By default, agent markdown is post-processed: ANSI-styled"," on a TTY, stripped to plain text on a pipe, tables laid"," out in both modes. Tool calls / thoughts split paragraphs"," but otherwise stay hidden. --raw bypasses the renderer"," and emits chunks immediately, the way cat used to behave."," With --session, attach to an existing session instead"," of creating a new one. With --detach, the session"," survives in the daemon for slack/browser/notifier"," extensions."," hydra-acp launch <agent> [agent-args...]"," Shim mode, force daemon to spawn <agent>"," from the registry. Args after <agent>"," are forwarded to the agent's command.","","Session selection (any entry point):"," --session <id> Attach to a local session by id."," --session hydra://host[:port]/id Attach to a session on another daemon (loopback uses the local service"," token; remote hosts use the cached credential from ~/.hydra-acp/remotes.json,"," falling back to a password prompt \u2014 but only on the TUI path)."," --session hydra://host/ URL with no id: picker (TUI) or fresh session (shim/cat)."," --reattach Pick the most-recent session for the current cwd."," --new Force a fresh session."," --readonly Open a session as a transcript viewer (requires --session)."," --dangerously-skip-permissions Auto-approve every tool permission request (tui / shim / launch / cat)."," HYDRA_ACP_SESSION Env var equivalent of --session (flag wins)."," hydra-acp init [--rotate-token] Initialize ~/.hydra-acp/config.json"," hydra-acp daemon [status] Show daemon pid/version (default when no subcommand)"," hydra-acp daemon start [--foreground] Start daemon (detached by default; --foreground to attach)"," hydra-acp daemon stop|restart"," hydra-acp daemon log [-f] [-n N] Tail or follow the daemon log"," hydra-acp session [list] [--all] [--json] [--host=<host>] [--include-non-interactive] [--columns=<list>]"," List sessions (live + 20 most-recent cold; --all lifts the cold cap AND surfaces non-interactive sessions; --json emits JSON for scripts)."," --host filters by origin machine: 'local' (default) shows only sessions created here, 'all' shows everything, or pass a hostname (e.g. machine-b) to show only imports from that peer."," --include-non-interactive surfaces ancillary (e.g. `hydra cat`) or never-prompted sessions while keeping the cold cap (a narrower --all)."," --columns picks which columns show and their order, e.g. --columns=session,state,title,cost (valid: session,upstream,host,state,agent,model,age,cwd,title,cost). UPSTREAM/HOST/MODEL hidden by default; COST is the trailing column; overrides config.tui.sessionColumns."," hydra-acp session info <id> [--verbose] [--json] [--diff] [--fold] [--no-color] [--no-pager]"," Aggregate one session: turn count, tool histogram, files touched, cost/duration, synopsis. --diff appends the session diff under the summary and pages the whole thing on a TTY (inherits --fold)."," hydra-acp session diff <id> [--json] [--no-color] [--no-pager] [--fold]"," Print a git-diff-shaped view of every file the session edited, reconstructed from history (no git). Pages through $HYDRA_ACP_PAGER / $PAGER / less on a TTY (LESS=FRX default); --no-pager bypasses. --fold collapses sequential hunks that rewrite the same region into one net-effect hunk."," hydra-acp session kill <id> Demote a live session to cold (keeps the on-disk record)"," hydra-acp session remove <id> Remove a session entirely (live or cold)"," hydra-acp session collect [--max-age-days <n>] [--limit <n>] [--keep-undecided] [--json]"," Delete cold sessions that were never promoted to a real conversation \u2014 `hydra cat` one-shots (interactive=false) AND editor-spawned panels that never had a turn (interactive=undefined). With no --max-age-days, collects every matching cold row regardless of age (you typed `collect`, so collect it all). Pass --max-age-days N to scope to anything older than N days; 0 is the same as omitting it. --keep-undecided narrows to only explicit interactive=false rows (matches what the background timer does). --limit caps deletions per call (default 1000); re-run to drain a larger backlog. The daemon also runs this on a timer using config.daemon.sessionGcMaxAgeDays (with the conservative explicit-only policy) \u2014 this is the manual trigger."," hydra-acp session export <id> [--out <file>|.]"," Write a session bundle to <file>, to a default-named file when --out=., or to stdout"," hydra-acp session transcript <id>|<file> [--out <file>|.]"," Render a session as a markdown transcript. Accepts a session id (renders via the daemon) or a local .hydra bundle file (rendered in-process). Writes to <file>, to a default-named file when --out=., or to stdout"," hydra-acp session import <file>|- [--replace] [--cwd <path>] [--info]"," Import a bundle from <file> or stdin (-); --replace overwrites a lineage match (kills it if live); --cwd overrides the bundle's recorded working directory; --info prints the bundle's meta without importing"," hydra-acp session share [<id>] [--host <name>] [--cwd <path>]"," Print a hydra:// URL the recipient can paste into `--session`. With no id, picks the most-recent session for cwd. Host precedence: --host > config.daemon.publicHost > config.daemon.host > 127.0.0.1 (with a stderr warning that the URL is loopback-only)."," hydra-acp extension list List configured extensions and live state"," hydra-acp extension add <name> [opts] Add an extension to config"," hydra-acp extension remove <name> Remove an extension from config"," hydra-acp extension start|stop|restart <n>|all Lifecycle on one or all"," hydra-acp extension log <name> [-f] [-n N] Tail or follow an extension's log"," hydra-acp transformer list List configured transformers and live state"," hydra-acp transformer add <name> [opts] Add a transformer to config (--command, --args, --env, --disabled)"," hydra-acp transformer remove <name> Remove a transformer from config"," hydra-acp transformer start|stop|restart <n>|all Lifecycle on one or all"," hydra-acp transformer log <name> [-f] [-n N] Tail or follow a transformer's log"," hydra-acp agent [list] List agents in the cached registry"," hydra-acp agent refresh Force a registry re-fetch"," hydra-acp agent install <id> Pre-install <id> from the registry (else lazy on first session)"," hydra-acp agent set [<id>] [model] With no args, report the daemon's current default agent and its default model. With <id>, set <id> as the default agent (config.defaultAgent). With <id> and [model], set the per-agent default model (config.defaultModels[<id>])."," hydra-acp agent pin <id> [packageSpec] Pin a registry agent to a specific npm version (e.g. opencode-ai@0.5.12). Omit packageSpec to clear. Sidesteps a broken upstream publish."," hydra-acp agent add <id> [--command CMD] [--args A,B,C] [--env K=V]... Define a local agent that bypasses the registry (e.g. your system `opencode`). --command defaults to <id> (resolved off PATH)."," hydra-acp agent remove <id> Remove a local agent."," hydra-acp registry pin | unpin Freeze the daemon on its cached registry (pin) so a bad push isn't picked up, or resume normal TTL fetching (unpin). `agent refresh` still forces a fetch."," hydra-acp agent sync <id> Spawn <id> just long enough to ACP session/list it, then persist any sessions it remembers (across every cwd) as cold rows in `session list`"," hydra-acp agent log <id> [-f] [-n N] Tail or follow an agent's spawn/stderr log"," hydra-acp auth password [--force] Set the daemon's master password"," hydra-acp auth [list] List active session tokens"," hydra-acp auth revoke <id> Revoke a session token"," hydra-acp tui flags: [--session <id-or-url>] [--reattach] [--new] [--readonly] [--agent <id>] [--model <id>] [--cwd <path>] [--name <label>]"," Smart default (no flags): shows a picker when sessions exist, else new."," hydra-acp --version Print version"," hydra-acp --help Show this help","","External subcommands:"," Any `hydra-acp <name>` whose <name> is not built-in is exec'd as"," `hydra-acp-<name>` from PATH (git-style). Ecosystem packages like"," @hydra-acp/planner expose themselves through this mechanism.","","Config knob flags accept env-var equivalents (flag wins):"," --agent HYDRA_ACP_AGENT"," --model HYDRA_ACP_MODEL (one-shot at session/new; ignored on --session resume)"," --session HYDRA_ACP_SESSION (session id or hydra:// URL)"," --name HYDRA_ACP_NAME",""].join(`
|
|
464
|
-
`))}async function
|
|
465
|
-
`)}catch{}}
|
|
466
|
-
`),await
|
|
482
|
+
`),Oc(),process.exit(2))}function _c(t){for(let e=0;e<t.length;e+=1){let n=t[e];if(n!==void 0){if(n==="-p")return t[e+1];if(n.startsWith("-p")&&!n.startsWith("--"))return n.slice(2)}}}async function Uh(t,e){try{return await Sl(t,e)}catch(n){process.stderr.write(`${n.message}
|
|
483
|
+
`),process.exit(1)}}function lx(){try{let t=ax(ox(import.meta.url));return JSON.parse(ix(dx(t,"../package.json"),"utf8")).version??"unknown"}catch{return"unknown"}}function Oc(){process.stdout.write(["hydra-acp \u2014 multi-client ACP session daemon","","Usage:"," hydra-acp [--session <id-or-url>] [--reattach] [opts]"," Auto: TUI when stdout is a TTY, shim otherwise (the editor-spawned case)."," With -p / --prompt and no subcommand, auto-dispatch to cat."," hydra-acp tui [same flags] Force TUI explicitly."," hydra-acp shim [same flags] Force shim explicitly (non-interactive; password prompts not allowed)."," hydra-acp cat [-p <prompt>] [--session <id-or-url>] [--detach] [--raw] [--agent <id>] [--model <id>] [--name <label>]"," Pipe-friendly headless mode. Reads stdin and sends it"," as a prompt to a fresh session, streams the agent's"," response to stdout, exits when stdin closes. A bounded",' input (e.g. `cat file.log | hydra cat -p "..."`) goes in'," as one turn; a streaming input (e.g. `tail -f`) is"," chunked by the natural pauses in the writer. -p is an"," optional standing instruction prepended to every chunk;"," if stdin already contains the question, -p is not needed."," By default, agent markdown is post-processed: ANSI-styled"," on a TTY, stripped to plain text on a pipe, tables laid"," out in both modes. Tool calls / thoughts split paragraphs"," but otherwise stay hidden. --raw bypasses the renderer"," and emits chunks immediately, the way cat used to behave."," With --session, attach to an existing session instead"," of creating a new one. With --detach, the session"," survives in the daemon for slack/browser/notifier"," extensions."," hydra-acp launch <agent> [agent-args...]"," Shim mode, force daemon to spawn <agent>"," from the registry. Args after <agent>"," are forwarded to the agent's command.","","Session selection (any entry point):"," --session <id> Attach to a local session by id."," --session hydra://host[:port]/id Attach to a session on another daemon (loopback uses the local service"," token; remote hosts use the cached credential from ~/.hydra-acp/remotes.json,"," falling back to a password prompt \u2014 but only on the TUI path)."," --session hydra://host/ URL with no id: picker (TUI) or fresh session (shim/cat)."," --reattach Pick the most-recent session for the current cwd."," --new Force a fresh session."," --readonly Open a session as a transcript viewer (requires --session)."," --dangerously-skip-permissions Auto-approve every tool permission request (tui / shim / launch / cat)."," HYDRA_ACP_SESSION Env var equivalent of --session (flag wins)."," hydra-acp init [--rotate-token] Initialize ~/.hydra-acp/config.json"," hydra-acp daemon [status] Show daemon pid/version (default when no subcommand)"," hydra-acp daemon start [--foreground] Start daemon (detached by default; --foreground to attach)"," hydra-acp daemon stop|restart"," hydra-acp daemon log [-f] [-n N] Tail or follow the daemon log"," hydra-acp session [list] [--all] [--json] [--host=<host>] [--include-non-interactive] [--columns=<list>]"," List sessions (live + 20 most-recent cold; --all lifts the cold cap AND surfaces non-interactive sessions; --json emits JSON for scripts)."," --host filters by origin machine: 'local' (default) shows only sessions created here, 'all' shows everything, or pass a hostname (e.g. machine-b) to show only imports from that peer."," --include-non-interactive surfaces ancillary (e.g. `hydra cat`) or never-prompted sessions while keeping the cold cap (a narrower --all)."," --columns picks which columns show and their order, e.g. --columns=session,state,title,cost (valid: session,upstream,host,state,agent,model,age,cwd,title,cost). UPSTREAM/HOST/MODEL hidden by default; COST is the trailing column; overrides config.tui.sessionColumns."," hydra-acp session info <id> [--verbose] [--json] [--diff] [--fold] [--no-color] [--no-pager]"," Aggregate one session: turn count, tool histogram, files touched, cost/duration, synopsis. --diff appends the session diff under the summary and pages the whole thing on a TTY (inherits --fold)."," hydra-acp session diff <id> [--json] [--no-color] [--no-pager] [--fold]"," Print a git-diff-shaped view of every file the session edited, reconstructed from history (no git). Pages through $HYDRA_ACP_PAGER / $PAGER / less on a TTY (LESS=FRX default); --no-pager bypasses. --fold collapses sequential hunks that rewrite the same region into one net-effect hunk."," hydra-acp session kill <id> Demote a live session to cold (keeps the on-disk record)"," hydra-acp session remove <id> Remove a session entirely (live or cold)"," hydra-acp session collect [--max-age-days <n>] [--limit <n>] [--keep-undecided] [--json]"," Delete cold sessions that were never promoted to a real conversation \u2014 `hydra cat` one-shots (interactive=false) AND editor-spawned panels that never had a turn (interactive=undefined). With no --max-age-days, collects every matching cold row regardless of age (you typed `collect`, so collect it all). Pass --max-age-days N to scope to anything older than N days; 0 is the same as omitting it. --keep-undecided narrows to only explicit interactive=false rows (matches what the background timer does). --limit caps deletions per call (default 1000); re-run to drain a larger backlog. The daemon also runs this on a timer using config.daemon.sessionGcMaxAgeDays (with the conservative explicit-only policy) \u2014 this is the manual trigger."," hydra-acp session export <id> [--out <file>|.]"," Write a session bundle to <file>, to a default-named file when --out=., or to stdout"," hydra-acp session transcript <id>|<file> [--out <file>|.]"," Render a session as a markdown transcript. Accepts a session id (renders via the daemon) or a local .hydra bundle file (rendered in-process). Writes to <file>, to a default-named file when --out=., or to stdout"," hydra-acp session import <file>|- [--replace] [--cwd <path>] [--info]"," Import a bundle from <file> or stdin (-); --replace overwrites a lineage match (kills it if live); --cwd overrides the bundle's recorded working directory; --info prints the bundle's meta without importing"," hydra-acp session share [<id>] [--host <name>] [--cwd <path>]"," Print a hydra:// URL the recipient can paste into `--session`. With no id, picks the most-recent session for cwd. Host precedence: --host > config.daemon.publicHost > config.daemon.host > 127.0.0.1 (with a stderr warning that the URL is loopback-only)."," hydra-acp extension list List configured extensions and live state"," hydra-acp extension add <name> [opts] Add an extension to config"," hydra-acp extension remove <name> Remove an extension from config"," hydra-acp extension start|stop|restart <n>|all Lifecycle on one or all"," hydra-acp extension log <name> [-f] [-n N] Tail or follow an extension's log"," hydra-acp transformer list List configured transformers and live state"," hydra-acp transformer add <name> [opts] Add a transformer to config (--command, --args, --env, --disabled)"," hydra-acp transformer remove <name> Remove a transformer from config"," hydra-acp transformer start|stop|restart <n>|all Lifecycle on one or all"," hydra-acp transformer log <name> [-f] [-n N] Tail or follow a transformer's log"," hydra-acp agent [list] List agents in the cached registry"," hydra-acp agent refresh Force a registry re-fetch"," hydra-acp agent install <id> Pre-install <id> from the registry (else lazy on first session)"," hydra-acp agent set [<id>] [model] With no args, report the daemon's current default agent and its default model. With <id>, set <id> as the default agent (config.defaultAgent). With <id> and [model], set the per-agent default model (config.defaultModels[<id>])."," hydra-acp agent pin <id> [packageSpec] Pin a registry agent to a specific npm version (e.g. opencode-ai@0.5.12). Omit packageSpec to clear. Sidesteps a broken upstream publish."," hydra-acp agent add <id> [--command CMD] [--args A,B,C] [--env K=V]... Define a local agent that bypasses the registry (e.g. your system `opencode`). --command defaults to <id> (resolved off PATH)."," hydra-acp agent remove <id> Remove a local agent."," hydra-acp registry pin | unpin Freeze the daemon on its cached registry (pin) so a bad push isn't picked up, or resume normal TTL fetching (unpin). `agent refresh` still forces a fetch."," hydra-acp agent sync <id> Spawn <id> just long enough to ACP session/list it, then persist any sessions it remembers (across every cwd) as cold rows in `session list`"," hydra-acp agent log <id> [-f] [-n N] Tail or follow an agent's spawn/stderr log"," hydra-acp auth password [--force] Set the daemon's master password"," hydra-acp auth [list] List active session tokens"," hydra-acp auth revoke <id> Revoke a session token"," hydra-acp tui flags: [--session <id-or-url>] [--reattach] [--new] [--readonly] [--agent <id>] [--model <id>] [--cwd <path>] [--name <label>]"," Smart default (no flags): shows a picker when sessions exist, else new."," hydra-acp --version Print version"," hydra-acp --help Show this help","","External subcommands:"," Any `hydra-acp <name>` whose <name> is not built-in is exec'd as"," `hydra-acp-<name>` from PATH (git-style). Ecosystem packages like"," @hydra-acp/planner expose themselves through this mechanism.","","Config knob flags accept env-var equivalents (flag wins):"," --agent HYDRA_ACP_AGENT"," --model HYDRA_ACP_MODEL (one-shot at session/new; ignored on --session resume)"," --session HYDRA_ACP_SESSION (session id or hydra:// URL)"," --name HYDRA_ACP_NAME",""].join(`
|
|
484
|
+
`))}async function jh(){if(!vs)try{let t=await li();t&&process.stderr.write(`\u2728 ${ui(t)}
|
|
485
|
+
`)}catch{}}cx().then(jh).catch(async t=>{process.stderr.write(`hydra-acp: ${t.message}
|
|
486
|
+
`),await jh(),process.exit(1)});
|