@wendongfly/zihi 1.1.8 → 1.1.10

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/index.js CHANGED
@@ -461,7 +461,7 @@ Set the \`cycles\` parameter to \`"ref"\` to resolve cyclical schemas with defs.
461
461
  ]`;continue}p+=d[b],d[b]==="\\"?h=!0:x&&d[b]==="]"?x=!1:!x&&d[b]==="["&&(x=!0)}try{new RegExp(p)}catch{return console.warn(`Could not convert regex pattern at ${t.currentPath.join("/")} to a flag-independent form! Falling back to the flag-ignorant source`),r.source}return p}function wQ(r,t){if(t.target==="openAi"&&console.warn("Warning: OpenAI may not support records in schemas! Try an array of key-value pairs instead."),t.target==="openApi3"&&r.keyType?._def.typeName===P.ZodEnum)return{type:"object",required:r.keyType._def.values,properties:r.keyType._def.values.reduce(((d,p)=>({...d,[p]:c(r.valueType._def,{...t,currentPath:[...t.currentPath,"properties",p]})??I$(t)})),{}),additionalProperties:t.rejectedAdditionalProperties};let u={type:"object",additionalProperties:c(r.valueType._def,{...t,currentPath:[...t.currentPath,"additionalProperties"]})??t.allowedAdditionalProperties};if(t.target==="openApi3")return u;if(r.keyType?._def.typeName===P.ZodString&&r.keyType._def.checks?.length){let{type:d,...p}=OQ(r.keyType._def,t);return{...u,propertyNames:p}}else{if(r.keyType?._def.typeName===P.ZodEnum)return{...u,propertyNames:{enum:r.keyType._def.values}};if(r.keyType?._def.typeName===P.ZodBranded&&r.keyType._def.type._def.typeName===P.ZodString&&r.keyType._def.type._def.checks?.length){let{type:d,...p}=VQ(r.keyType._def,t);return{...u,propertyNames:p}}}return u}function nV(r,t){if(t.mapStrategy==="record")return wQ(r,t);let u=c(r.keyType._def,{...t,currentPath:[...t.currentPath,"items","items","0"]})||I$(t),d=c(r.valueType._def,{...t,currentPath:[...t.currentPath,"items","items","1"]})||I$(t);return{type:"array",maxItems:125,items:{type:"array",items:[u,d],minItems:2,maxItems:2}}}function dV(r){let t=r.values,u=Object.keys(r.values).filter((p=>typeof t[t[p]]!="number")).map((p=>t[p])),d=Array.from(new Set(u.map((p=>typeof p))));return{type:d.length===1?d[0]==="string"?"string":"number":["string","number"],enum:u}}function rV(r){return r.target==="openAi"?void 0:{not:I$({...r,currentPath:[...r.currentPath,"not"]})}}function oV(r){return r.target==="openApi3"?{enum:["null"],nullable:!0}:{type:"null"}}var M9={ZodString:"string",ZodNumber:"number",ZodBigInt:"integer",ZodBoolean:"boolean",ZodNull:"null"};function aV(r,t){if(t.target==="openApi3")return tV(r,t);let u=r.options instanceof Map?Array.from(r.options.values()):r.options;if(u.every((d=>d._def.typeName in M9&&(!d._def.checks||!d._def.checks.length)))){let d=u.reduce(((p,h)=>{let x=M9[h._def.typeName];return x&&!p.includes(x)?[...p,x]:p}),[]);return{type:d.length>1?d:d[0]}}else if(u.every((d=>d._def.typeName==="ZodLiteral"&&!d.description))){let d=u.reduce(((p,h)=>{let x=typeof h._def.value;switch(x){case"string":case"number":case"boolean":return[...p,x];case"bigint":return[...p,"integer"];case"object":if(h._def.value===null)return[...p,"null"];default:return p}}),[]);if(d.length===u.length){let p=d.filter(((h,x,$)=>$.indexOf(h)===x));return{type:p.length>1?p:p[0],enum:u.reduce(((h,x)=>h.includes(x._def.value)?h:[...h,x._def.value]),[])}}}else if(u.every((d=>d._def.typeName==="ZodEnum")))return{type:"string",enum:u.reduce(((d,p)=>[...d,...p._def.values.filter((h=>!d.includes(h)))]),[])};return tV(r,t)}var tV=(r,t)=>{let u=(r.options instanceof Map?Array.from(r.options.values()):r.options).map(((d,p)=>c(d._def,{...t,currentPath:[...t.currentPath,"anyOf",`${p}`]}))).filter((d=>!!d&&(!t.strictUnions||typeof d=="object"&&Object.keys(d).length>0)));return u.length?{anyOf:u}:void 0};function sV(r,t){if(["ZodString","ZodNumber","ZodBigInt","ZodBoolean","ZodNull"].includes(r.innerType._def.typeName)&&(!r.innerType._def.checks||!r.innerType._def.checks.length))return t.target==="openApi3"?{type:M9[r.innerType._def.typeName],nullable:!0}:{type:[M9[r.innerType._def.typeName],"null"]};if(t.target==="openApi3"){let d=c(r.innerType._def,{...t,currentPath:[...t.currentPath]});return d&&"$ref"in d?{allOf:[d],nullable:!0}:d&&{...d,nullable:!0}}let u=c(r.innerType._def,{...t,currentPath:[...t.currentPath,"anyOf","0"]});return u&&{anyOf:[u,{type:"null"}]}}function eV(r,t){let u={type:"number"};if(!r.checks)return u;for(let d of r.checks)switch(d.kind){case"int":u.type="integer",w3(u,"type",d.message,t);break;case"min":t.target==="jsonSchema7"?d.inclusive?J$(u,"minimum",d.value,d.message,t):J$(u,"exclusiveMinimum",d.value,d.message,t):(d.inclusive||(u.exclusiveMinimum=!0),J$(u,"minimum",d.value,d.message,t));break;case"max":t.target==="jsonSchema7"?d.inclusive?J$(u,"maximum",d.value,d.message,t):J$(u,"exclusiveMaximum",d.value,d.message,t):(d.inclusive||(u.exclusiveMaximum=!0),J$(u,"maximum",d.value,d.message,t));break;case"multipleOf":J$(u,"multipleOf",d.value,d.message,t);break}return u}function $O(r,t){let u=t.target==="openAi",d={type:"object",properties:{}},p=[],h=r.shape();for(let $ in h){let b=h[$];if(b===void 0||b._def===void 0)continue;let w=OZ(b);w&&u&&(b._def.typeName==="ZodOptional"&&(b=b._def.innerType),b.isNullable()||(b=b.nullable()),w=!1);let j=c(b._def,{...t,currentPath:[...t.currentPath,"properties",$],propertyPath:[...t.currentPath,"properties",$]});j!==void 0&&(d.properties[$]=j,!w&&p.push($))}p.length&&(d.required=p);let x=VZ(r,t);return x!==void 0&&(d.additionalProperties=x),d}function VZ(r,t){if(r.catchall._def.typeName!=="ZodNever")return c(r.catchall._def,{...t,currentPath:[...t.currentPath,"additionalProperties"]});switch(r.unknownKeys){case"passthrough":return t.allowedAdditionalProperties;case"strict":return t.rejectedAdditionalProperties;case"strip":return t.removeAdditionalStrategy==="strict"?t.allowedAdditionalProperties:t.rejectedAdditionalProperties}}function OZ(r){try{return r.isOptional()}catch{return!0}}var XO=(r,t)=>{if(t.currentPath.toString()===t.propertyPath?.toString())return c(r.innerType._def,t);let u=c(r.innerType._def,{...t,currentPath:[...t.currentPath,"anyOf","1"]});return u?{anyOf:[{not:I$(t)},u]}:I$(t)},JO=(r,t)=>{if(t.pipeStrategy==="input")return c(r.in._def,t);if(t.pipeStrategy==="output")return c(r.out._def,t);let u=c(r.in._def,{...t,currentPath:[...t.currentPath,"allOf","0"]}),d=c(r.out._def,{...t,currentPath:[...t.currentPath,"allOf",u?"1":"0"]});return{allOf:[u,d].filter((p=>p!==void 0))}};function YO(r,t){return c(r.type._def,t)}function QO(r,t){let u={type:"array",uniqueItems:!0,items:c(r.valueType._def,{...t,currentPath:[...t.currentPath,"items"]})};return r.minSize&&J$(u,"minItems",r.minSize.value,r.minSize.message,t),r.maxSize&&J$(u,"maxItems",r.maxSize.value,r.maxSize.message,t),u}function zO(r,t){return r.rest?{type:"array",minItems:r.items.length,items:r.items.map(((u,d)=>c(u._def,{...t,currentPath:[...t.currentPath,"items",`${d}`]}))).reduce(((u,d)=>d===void 0?u:[...u,d]),[]),additionalItems:c(r.rest._def,{...t,currentPath:[...t.currentPath,"additionalItems"]})}:{type:"array",minItems:r.items.length,maxItems:r.items.length,items:r.items.map(((u,d)=>c(u._def,{...t,currentPath:[...t.currentPath,"items",`${d}`]}))).reduce(((u,d)=>d===void 0?u:[...u,d]),[])}}function WO(r){return{not:I$(r)}}function GO(r){return I$(r)}var UO=(r,t)=>c(r.innerType._def,t),HO=(r,t,u)=>{switch(t){case P.ZodString:return OQ(r,u);case P.ZodNumber:return eV(r,u);case P.ZodObject:return $O(r,u);case P.ZodBigInt:return fV(r,u);case P.ZodBoolean:return gV();case P.ZodDate:return B3(r,u);case P.ZodUndefined:return WO(u);case P.ZodNull:return oV(u);case P.ZodArray:return yV(r,u);case P.ZodUnion:case P.ZodDiscriminatedUnion:return aV(r,u);case P.ZodIntersection:return cV(r,u);case P.ZodTuple:return zO(r,u);case P.ZodRecord:return wQ(r,u);case P.ZodLiteral:return pV(r,u);case P.ZodEnum:return lV(r);case P.ZodNativeEnum:return dV(r);case P.ZodNullable:return sV(r,u);case P.ZodOptional:return XO(r,u);case P.ZodMap:return nV(r,u);case P.ZodSet:return QO(r,u);case P.ZodLazy:return()=>r.getter()._def;case P.ZodPromise:return YO(r,u);case P.ZodNaN:case P.ZodNever:return rV(u);case P.ZodEffects:return mV(r,u);case P.ZodAny:return I$(u);case P.ZodUnknown:return GO(u);case P.ZodDefault:return uV(r,u);case P.ZodBranded:return VQ(r,u);case P.ZodReadonly:return UO(r,u);case P.ZodCatch:return hV(r,u);case P.ZodPipeline:return JO(r,u);case P.ZodFunction:case P.ZodVoid:case P.ZodSymbol:return;default:return(d=>{})(t)}};function c(r,t,u=!1){let d=t.seen.get(r);if(t.override){let $=t.override?.(r,t,d,u);if($!==_V)return $}if(d&&!u){let $=wZ(d,t);if($!==void 0)return $}let p={def:r,path:t.currentPath,jsonSchema:void 0};t.seen.set(r,p);let h=HO(r,r.typeName,t),x=typeof h=="function"?c(h(),t):h;if(x&&BZ(r,t,x),t.postProcess){let $=t.postProcess(x,r,t);return p.jsonSchema=x,$}return p.jsonSchema=x,x}var wZ=(r,t)=>{switch(t.$refStrategy){case"root":return{$ref:r.path.join("/")};case"relative":return{$ref:NQ(t.currentPath,r.path)};case"none":case"seen":return r.path.length<t.currentPath.length&&r.path.every(((u,d)=>t.currentPath[d]===u))?(console.warn(`Recursive reference detected at ${t.currentPath.join("/")}! Defaulting to any`),I$(t)):t.$refStrategy==="seen"?I$(t):void 0}},BZ=(r,t,u)=>(r.description&&(u.description=r.description,t.markdownDescription&&(u.markdownDescription=r.description)),u),L3=(r,t)=>{let u=TV(t),d=typeof t=="object"&&t.definitions?Object.entries(t.definitions).reduce(((b,[w,j])=>({...b,[w]:c(j._def,{...u,currentPath:[...u.basePath,u.definitionPath,w]},!0)??I$(u)})),{}):void 0,p=typeof t=="string"?t:t?.nameStrategy==="title"?void 0:t?.name,h=c(r._def,p===void 0?u:{...u,currentPath:[...u.basePath,u.definitionPath,p]},!1)??I$(u),x=typeof t=="object"&&t.name!==void 0&&t.nameStrategy==="title"?t.name:void 0;x!==void 0&&(h.title=x),u.flags.hasReferencedOpenAiAnyType&&(d||(d={}),d[u.openAiAnyTypeName]||(d[u.openAiAnyTypeName]={type:["string","number","integer","boolean","array","null"],items:{$ref:u.$refStrategy==="relative"?"1":[...u.basePath,u.definitionPath,u.openAiAnyTypeName].join("/")}}));let $=p===void 0?d?{...h,[u.definitionPath]:d}:h:{$ref:[...u.$refStrategy==="relative"?[]:u.basePath,u.definitionPath,p].join("/"),[u.definitionPath]:{...d,[p]:h}};return u.target==="jsonSchema7"?$.$schema="http://json-schema.org/draft-07/schema#":(u.target==="jsonSchema2019-09"||u.target==="openAi")&&($.$schema="https://json-schema.org/draft/2019-09/schema#"),u.target==="openAi"&&("anyOf"in $||"oneOf"in $||"allOf"in $||"type"in $&&Array.isArray($.type))&&console.warn("Warning: OpenAI may not support schemas with unions as roots! Try wrapping it in an object property."),$};function qZ(r){return!r||r==="jsonSchema7"||r==="draft-7"?"draft-7":r==="jsonSchema2019-09"||r==="draft-2020-12"?"draft-2020-12":"draft-7"}function j3(r,t){return A6(r)?Z0(r,{target:qZ(t?.target),io:t?.pipeStrategy??"input"}):L3(r,{strictUnions:t?.strictUnions??!0,pipeStrategy:t?.pipeStrategy??"input"})}function F3(r){let t=h4(r)?.method;if(!t)throw Error("Schema is missing a method literal");let u=v7(t);if(typeof u!="string")throw Error("Schema method literal must be a string");return u}function M3(r,t){let u=g4(r,t);if(!u.success)throw u.error;return u.data}var DZ=6e4;class I3{constructor(t){this._options=t,this._requestMessageId=0,this._requestHandlers=new Map,this._requestHandlerAbortControllers=new Map,this._notificationHandlers=new Map,this._responseHandlers=new Map,this._progressHandlers=new Map,this._timeoutInfo=new Map,this._pendingDebouncedNotifications=new Set,this._taskProgressTokens=new Map,this._requestResolvers=new Map,this.setNotificationHandler(r7,(u=>{this._oncancel(u)})),this.setNotificationHandler(t7,(u=>{this._onprogress(u)})),this.setRequestHandler(o7,(u=>({}))),this._taskStore=t?.taskStore,this._taskMessageQueue=t?.taskMessageQueue,this._taskStore&&(this.setRequestHandler(a7,(async(u,d)=>{let p=await this._taskStore.getTask(u.params.taskId,d.sessionId);if(!p)throw new g(m.InvalidParams,"Failed to retrieve task: Task not found");return{...p}})),this.setRequestHandler(e7,(async(u,d)=>{let p=async()=>{let h=u.params.taskId;if(this._taskMessageQueue){let $;for(;$=await this._taskMessageQueue.dequeue(h,d.sessionId);){if($.type==="response"||$.type==="error"){let b=$.message,w=b.id,j=this._requestResolvers.get(w);if(j)if(this._requestResolvers.delete(w),$.type==="response")j(b);else{let N=b,I=new g(N.error.code,N.error.message,N.error.data);j(I)}else{let N=$.type==="response"?"Response":"Error";this._onerror(Error(`${N} handler missing for request ${w}`))}continue}await this._transport?.send($.message,{relatedRequestId:d.requestId})}}let x=await this._taskStore.getTask(h,d.sessionId);if(!x)throw new g(m.InvalidParams,`Task not found: ${h}`);if(!l4(x.status))return await this._waitForTaskUpdate(h,d.signal),await p();if(l4(x.status)){let $=await this._taskStore.getTaskResult(h,d.sessionId);return this._clearTaskQueue(h),{...$,_meta:{...$._meta,[m4]:{taskId:h}}}}return await p()};return await p()})),this.setRequestHandler($Q,(async(u,d)=>{try{let{tasks:p,nextCursor:h}=await this._taskStore.listTasks(u.params?.cursor,d.sessionId);return{tasks:p,nextCursor:h,_meta:{}}}catch(p){throw new g(m.InvalidParams,`Failed to list tasks: ${p instanceof Error?p.message:String(p)}`)}})),this.setRequestHandler(JQ,(async(u,d)=>{try{let p=await this._taskStore.getTask(u.params.taskId,d.sessionId);if(!p)throw new g(m.InvalidParams,`Task not found: ${u.params.taskId}`);if(l4(p.status))throw new g(m.InvalidParams,`Cannot cancel task in terminal status: ${p.status}`);await this._taskStore.updateTaskStatus(u.params.taskId,"cancelled","Client cancelled task execution.",d.sessionId),this._clearTaskQueue(u.params.taskId);let h=await this._taskStore.getTask(u.params.taskId,d.sessionId);if(!h)throw new g(m.InvalidParams,`Task not found after cancellation: ${u.params.taskId}`);return{_meta:{},...h}}catch(p){throw p instanceof g?p:new g(m.InvalidRequest,`Failed to cancel task: ${p instanceof Error?p.message:String(p)}`)}})))}async _oncancel(t){t.params.requestId&&this._requestHandlerAbortControllers.get(t.params.requestId)?.abort(t.params.reason)}_setupTimeout(t,u,d,p,h=!1){this._timeoutInfo.set(t,{timeoutId:setTimeout(p,u),startTime:Date.now(),timeout:u,maxTotalTimeout:d,resetTimeoutOnProgress:h,onTimeout:p})}_resetTimeout(t){let u=this._timeoutInfo.get(t);if(!u)return!1;let d=Date.now()-u.startTime;if(u.maxTotalTimeout&&d>=u.maxTotalTimeout)throw this._timeoutInfo.delete(t),g.fromError(m.RequestTimeout,"Maximum total timeout exceeded",{maxTotalTimeout:u.maxTotalTimeout,totalElapsed:d});return clearTimeout(u.timeoutId),u.timeoutId=setTimeout(u.onTimeout,u.timeout),!0}_cleanupTimeout(t){let u=this._timeoutInfo.get(t);u&&(clearTimeout(u.timeoutId),this._timeoutInfo.delete(t))}async connect(t){if(this._transport)throw Error("Already connected to a transport. Call close() before connecting to a new transport, or use a separate Protocol instance per connection.");this._transport=t;let u=this.transport?.onclose;this._transport.onclose=()=>{u?.(),this._onclose()};let d=this.transport?.onerror;this._transport.onerror=h=>{d?.(h),this._onerror(h)};let p=this._transport?.onmessage;this._transport.onmessage=(h,x)=>{p?.(h,x),V9(h)||MV(h)?this._onresponse(h):$3(h)?this._onrequest(h,x):FV(h)?this._onnotification(h):this._onerror(Error(`Unknown message type: ${JSON.stringify(h)}`))},await this._transport.start()}_onclose(){let t=this._responseHandlers;this._responseHandlers=new Map,this._progressHandlers.clear(),this._taskProgressTokens.clear(),this._pendingDebouncedNotifications.clear();for(let d of this._requestHandlerAbortControllers.values())d.abort();this._requestHandlerAbortControllers.clear();let u=g.fromError(m.ConnectionClosed,"Connection closed");this._transport=void 0,this.onclose?.();for(let d of t.values())d(u)}_onerror(t){this.onerror?.(t)}_onnotification(t){let u=this._notificationHandlers.get(t.method)??this.fallbackNotificationHandler;u!==void 0&&Promise.resolve().then((()=>u(t))).catch((d=>this._onerror(Error(`Uncaught error in notification handler: ${d}`))))}_onrequest(t,u){let d=this._requestHandlers.get(t.method)??this.fallbackRequestHandler,p=this._transport,h=t.params?._meta?.[m4]?.taskId;if(d===void 0){let j={jsonrpc:"2.0",id:t.id,error:{code:m.MethodNotFound,message:"Method not found"}};h&&this._taskMessageQueue?this._enqueueTaskMessage(h,{type:"error",message:j,timestamp:Date.now()},p?.sessionId).catch((N=>this._onerror(Error(`Failed to enqueue error response: ${N}`)))):p?.send(j).catch((N=>this._onerror(Error(`Failed to send an error response: ${N}`))));return}let x=new AbortController;this._requestHandlerAbortControllers.set(t.id,x);let $=DV(t.params)?t.params.task:void 0,b=this._taskStore?this.requestTaskStore(t,p?.sessionId):void 0,w={signal:x.signal,sessionId:p?.sessionId,_meta:t.params?._meta,sendNotification:async j=>{if(x.signal.aborted)return;let N={relatedRequestId:t.id};h&&(N.relatedTask={taskId:h}),await this.notification(j,N)},sendRequest:async(j,N,I)=>{if(x.signal.aborted)throw new g(m.ConnectionClosed,"Request was cancelled");let U={...I,relatedRequestId:t.id};h&&!U.relatedTask&&(U.relatedTask={taskId:h});let z=U.relatedTask?.taskId??h;return z&&b&&await b.updateTaskStatus(z,"input_required"),await this.request(j,N,U)},authInfo:u?.authInfo,requestId:t.id,requestInfo:u?.requestInfo,taskId:h,taskStore:b,taskRequestedTtl:$?.ttl,closeSSEStream:u?.closeSSEStream,closeStandaloneSSEStream:u?.closeStandaloneSSEStream};Promise.resolve().then((()=>{$&&this.assertTaskHandlerCapability(t.method)})).then((()=>d(t,w))).then((async j=>{if(x.signal.aborted)return;let N={result:j,jsonrpc:"2.0",id:t.id};h&&this._taskMessageQueue?await this._enqueueTaskMessage(h,{type:"response",message:N,timestamp:Date.now()},p?.sessionId):await p?.send(N)}),(async j=>{if(x.signal.aborted)return;let N={jsonrpc:"2.0",id:t.id,error:{code:Number.isSafeInteger(j.code)?j.code:m.InternalError,message:j.message??"Internal error",...j.data!==void 0&&{data:j.data}}};h&&this._taskMessageQueue?await this._enqueueTaskMessage(h,{type:"error",message:N,timestamp:Date.now()},p?.sessionId):await p?.send(N)})).catch((j=>this._onerror(Error(`Failed to send response: ${j}`)))).finally((()=>{this._requestHandlerAbortControllers.delete(t.id)}))}_onprogress(t){let{progressToken:u,...d}=t.params,p=Number(u),h=this._progressHandlers.get(p);if(!h){this._onerror(Error(`Received a progress notification for an unknown token: ${JSON.stringify(t)}`));return}let x=this._responseHandlers.get(p),$=this._timeoutInfo.get(p);if($&&x&&$.resetTimeoutOnProgress)try{this._resetTimeout(p)}catch(b){this._responseHandlers.delete(p),this._progressHandlers.delete(p),this._cleanupTimeout(p),x(b);return}h(d)}_onresponse(t){let u=Number(t.id),d=this._requestResolvers.get(u);if(d){if(this._requestResolvers.delete(u),V9(t))d(t);else{let x=new g(t.error.code,t.error.message,t.error.data);d(x)}return}let p=this._responseHandlers.get(u);if(p===void 0){this._onerror(Error(`Received a response for an unknown message ID: ${JSON.stringify(t)}`));return}this._responseHandlers.delete(u),this._cleanupTimeout(u);let h=!1;if(V9(t)&&t.result&&typeof t.result=="object"){let x=t.result;if(x.task&&typeof x.task=="object"){let $=x.task;typeof $.taskId=="string"&&(h=!0,this._taskProgressTokens.set($.taskId,u))}}if(h||this._progressHandlers.delete(u),V9(t))p(t);else{let x=g.fromError(t.error.code,t.error.message,t.error.data);p(x)}}get transport(){return this._transport}async close(){await this._transport?.close()}async*requestStream(t,u,d){let{task:p}=d??{};if(!p){try{yield{type:"result",result:await this.request(t,u,d)}}catch(x){yield{type:"error",error:x instanceof g?x:new g(m.InternalError,String(x))}}return}let h;try{let x=await this.request(t,k0,d);if(x.task)h=x.task.taskId,yield{type:"taskCreated",task:x.task};else throw new g(m.InternalError,"Task creation did not return a task");for(;;){let $=await this.getTask({taskId:h},d);if(yield{type:"taskStatus",task:$},l4($.status)){$.status==="completed"?yield{type:"result",result:await this.getTaskResult({taskId:h},u,d)}:$.status==="failed"?yield{type:"error",error:new g(m.InternalError,`Task ${h} failed`)}:$.status==="cancelled"&&(yield{type:"error",error:new g(m.InternalError,`Task ${h} was cancelled`)});return}if($.status==="input_required"){yield{type:"result",result:await this.getTaskResult({taskId:h},u,d)};return}let b=$.pollInterval??this._options?.defaultTaskPollInterval??1e3;await new Promise((w=>setTimeout(w,b))),d?.signal?.throwIfAborted()}}catch(x){yield{type:"error",error:x instanceof g?x:new g(m.InternalError,String(x))}}}request(t,u,d){let{relatedRequestId:p,resumptionToken:h,onresumptiontoken:x,task:$,relatedTask:b}=d??{};return new Promise(((w,j)=>{let N=W=>{j(W)};if(!this._transport){N(Error("Not connected"));return}if(this._options?.enforceStrictCapabilities===!0)try{this.assertCapabilityForMethod(t.method),$&&this.assertTaskCapability(t.method)}catch(W){N(W);return}d?.signal?.throwIfAborted();let I=this._requestMessageId++,U={...t,jsonrpc:"2.0",id:I};d?.onprogress&&(this._progressHandlers.set(I,d.onprogress),U.params={...t.params,_meta:{...t.params?._meta||{},progressToken:I}}),$&&(U.params={...U.params,task:$}),b&&(U.params={...U.params,_meta:{...U.params?._meta||{},[m4]:b}});let z=W=>{this._responseHandlers.delete(I),this._progressHandlers.delete(I),this._cleanupTimeout(I),this._transport?.send({jsonrpc:"2.0",method:"notifications/cancelled",params:{requestId:I,reason:String(W)}},{relatedRequestId:p,resumptionToken:h,onresumptiontoken:x}).catch((V=>this._onerror(Error(`Failed to send cancellation: ${V}`))));let H=W instanceof g?W:new g(m.RequestTimeout,String(W));j(H)};this._responseHandlers.set(I,(W=>{if(!d?.signal?.aborted){if(W instanceof Error)return j(W);try{let H=g4(u,W.result);H.success?w(H.data):j(H.error)}catch(H){j(H)}}})),d?.signal?.addEventListener("abort",(()=>{z(d?.signal?.reason)}));let O=d?.timeout??DZ,B=()=>z(g.fromError(m.RequestTimeout,"Request timed out",{timeout:O}));this._setupTimeout(I,O,d?.maxTotalTimeout,B,d?.resetTimeoutOnProgress??!1);let L=b?.taskId;if(L){let W=H=>{let V=this._responseHandlers.get(I);V?V(H):this._onerror(Error(`Response handler missing for side-channeled request ${I}`))};this._requestResolvers.set(I,W),this._enqueueTaskMessage(L,{type:"request",message:U,timestamp:Date.now()}).catch((H=>{this._cleanupTimeout(I),j(H)}))}else this._transport.send(U,{relatedRequestId:p,resumptionToken:h,onresumptiontoken:x}).catch((W=>{this._cleanupTimeout(I),j(W)}))}))}async getTask(t,u){return this.request({method:"tasks/get",params:t},s7,u)}async getTaskResult(t,u,d){return this.request({method:"tasks/result",params:t},u,d)}async listTasks(t,u){return this.request({method:"tasks/list",params:t},XQ,u)}async cancelTask(t,u){return this.request({method:"tasks/cancel",params:t},AV,u)}async notification(t,u){if(!this._transport)throw Error("Not connected");this.assertNotificationCapability(t.method);let d=u?.relatedTask?.taskId;if(d){let h={...t,jsonrpc:"2.0",params:{...t.params,_meta:{...t.params?._meta||{},[m4]:u.relatedTask}}};await this._enqueueTaskMessage(d,{type:"notification",message:h,timestamp:Date.now()});return}if((this._options?.debouncedNotificationMethods??[]).includes(t.method)&&!t.params&&!u?.relatedRequestId&&!u?.relatedTask){if(this._pendingDebouncedNotifications.has(t.method))return;this._pendingDebouncedNotifications.add(t.method),Promise.resolve().then((()=>{if(this._pendingDebouncedNotifications.delete(t.method),!this._transport)return;let h={...t,jsonrpc:"2.0"};u?.relatedTask&&(h={...h,params:{...h.params,_meta:{...h.params?._meta||{},[m4]:u.relatedTask}}}),this._transport?.send(h,u).catch((x=>this._onerror(x)))}));return}let p={...t,jsonrpc:"2.0"};u?.relatedTask&&(p={...p,params:{...p.params,_meta:{...p.params?._meta||{},[m4]:u.relatedTask}}}),await this._transport.send(p,u)}setRequestHandler(t,u){let d=F3(t);this.assertRequestHandlerCapability(d),this._requestHandlers.set(d,((p,h)=>{let x=M3(t,p);return Promise.resolve(u(x,h))}))}removeRequestHandler(t){this._requestHandlers.delete(t)}assertCanSetRequestHandler(t){if(this._requestHandlers.has(t))throw Error(`A request handler for ${t} already exists, which would be overridden`)}setNotificationHandler(t,u){let d=F3(t);this._notificationHandlers.set(d,(p=>{let h=M3(t,p);return Promise.resolve(u(h))}))}removeNotificationHandler(t){this._notificationHandlers.delete(t)}_cleanupTaskProgressHandler(t){let u=this._taskProgressTokens.get(t);u!==void 0&&(this._progressHandlers.delete(u),this._taskProgressTokens.delete(t))}async _enqueueTaskMessage(t,u,d){if(!this._taskStore||!this._taskMessageQueue)throw Error("Cannot enqueue task message: taskStore and taskMessageQueue are not configured");let p=this._options?.maxTaskQueueSize;await this._taskMessageQueue.enqueue(t,u,d,p)}async _clearTaskQueue(t,u){if(this._taskMessageQueue){let d=await this._taskMessageQueue.dequeueAll(t,u);for(let p of d)if(p.type==="request"&&$3(p.message)){let h=p.message.id,x=this._requestResolvers.get(h);x?(x(new g(m.InternalError,"Task cancelled or completed")),this._requestResolvers.delete(h)):this._onerror(Error(`Resolver missing for request ${h} during task ${t} cleanup`))}}}async _waitForTaskUpdate(t,u){let d=this._options?.defaultTaskPollInterval??1e3;try{let p=await this._taskStore?.getTask(t);p?.pollInterval&&(d=p.pollInterval)}catch{}return new Promise(((p,h)=>{if(u.aborted){h(new g(m.InvalidRequest,"Request cancelled"));return}let x=setTimeout(p,d);u.addEventListener("abort",(()=>{clearTimeout(x),h(new g(m.InvalidRequest,"Request cancelled"))}),{once:!0})}))}requestTaskStore(t,u){let d=this._taskStore;if(!d)throw Error("No task store configured");return{createTask:async p=>{if(!t)throw Error("No request provided");return await d.createTask(p,t.id,{method:t.method,params:t.params},u)},getTask:async p=>{let h=await d.getTask(p,u);if(!h)throw new g(m.InvalidParams,"Failed to retrieve task: Task not found");return h},storeTaskResult:async(p,h,x)=>{await d.storeTaskResult(p,h,x,u);let $=await d.getTask(p,u);if($){let b=D9.parse({method:"notifications/tasks/status",params:$});await this.notification(b),l4($.status)&&this._cleanupTaskProgressHandler(p)}},getTaskResult:p=>d.getTaskResult(p,u),updateTaskStatus:async(p,h,x)=>{let $=await d.getTask(p,u);if(!$)throw new g(m.InvalidParams,`Task "${p}" not found - it may have been cleaned up`);if(l4($.status))throw new g(m.InvalidParams,`Cannot update task "${p}" from terminal status "${$.status}" to "${h}". Terminal states (completed, failed, cancelled) cannot transition to other states.`);await d.updateTaskStatus(p,h,x,u);let b=await d.getTask(p,u);if(b){let w=D9.parse({method:"notifications/tasks/status",params:b});await this.notification(w),l4(b.status)&&this._cleanupTaskProgressHandler(p)}},listTasks:p=>d.listTasks(p,u)}}}function KO(r){return r!==null&&typeof r=="object"&&!Array.isArray(r)}function NO(r,t){let u={...r};for(let d in t){let p=d,h=t[p];if(h===void 0)continue;let x=u[p];KO(x)&&KO(h)?u[p]={...x,...h}:u[p]=h}return u}var rD=uU(BU(),1),oD=uU(dD(),1);function Zx(){let r=new rD.default({strict:!1,validateFormats:!0,validateSchema:!1,allErrors:!0});return oD.default(r),r}class PU{constructor(t){this._ajv=t??Zx()}getValidator(t){let u="$id"in t&&typeof t.$id=="string"?this._ajv.getSchema(t.$id)??this._ajv.compile(t):this._ajv.compile(t);return d=>u(d)?{valid:!0,data:d,errorMessage:void 0}:{valid:!1,data:void 0,errorMessage:this._ajv.errorsText(u.errors)}}}class ZU{constructor(t){this._server=t}requestStream(t,u,d){return this._server.requestStream(t,u,d)}createMessageStream(t,u){let d=this._server.getClientCapabilities();if((t.tools||t.toolChoice)&&!d?.sampling?.tools)throw Error("Client does not support sampling tools capability.");if(t.messages.length>0){let p=t.messages[t.messages.length-1],h=Array.isArray(p.content)?p.content:[p.content],x=h.some((j=>j.type==="tool_result")),$=t.messages.length>1?t.messages[t.messages.length-2]:void 0,b=$?Array.isArray($.content)?$.content:[$.content]:[],w=b.some((j=>j.type==="tool_use"));if(x){if(h.some((j=>j.type!=="tool_result")))throw Error("The last message must contain only tool_result content if any is present");if(!w)throw Error("tool_result blocks are not matching any tool_use from the previous message")}if(w){let j=new Set(b.filter((I=>I.type==="tool_use")).map((I=>I.id))),N=new Set(h.filter((I=>I.type==="tool_result")).map((I=>I.toolUseId)));if(j.size!==N.size||![...j].every((I=>N.has(I))))throw Error("ids of tool_result blocks and tool_use blocks from previous message do not match")}}return this.requestStream({method:"sampling/createMessage",params:t},F9,u)}elicitInputStream(t,u){let d=this._server.getClientCapabilities(),p=t.mode??"form";switch(p){case"url":{if(!d?.elicitation?.url)throw Error("Client does not support url elicitation.");break}case"form":{if(!d?.elicitation?.form)throw Error("Client does not support form elicitation.");break}}let h=p==="form"&&t.mode===void 0?{...t,mode:"form"}:t;return this.requestStream({method:"elicitation/create",params:h},T0,u)}async getTask(t,u){return this._server.getTask({taskId:t},u)}async getTaskResult(t,u,d){return this._server.getTaskResult({taskId:t},u,d)}async listTasks(t,u){return this._server.listTasks(t?{cursor:t}:void 0,u)}async cancelTask(t,u){return this._server.cancelTask({taskId:t},u)}}function tD(r,t,u){if(!r)throw Error(`${u} does not support task creation (required for ${t})`);switch(t){case"tools/call":if(!r.tools?.call)throw Error(`${u} does not support task creation for tools/call (required for ${t})`);break;default:break}}function aD(r,t,u){if(!r)throw Error(`${u} does not support task creation (required for ${t})`);switch(t){case"sampling/createMessage":if(!r.sampling?.createMessage)throw Error(`${u} does not support task creation for sampling/createMessage (required for ${t})`);break;case"elicitation/create":if(!r.elicitation?.create)throw Error(`${u} does not support task creation for elicitation/create (required for ${t})`);break;default:break}}class EU extends I3{constructor(t,u){super(u),this._serverInfo=t,this._loggingLevels=new Map,this.LOG_LEVEL_SEVERITY=new Map(j9.options.map(((d,p)=>[d,p]))),this.isMessageIgnored=(d,p)=>{let h=this._loggingLevels.get(p);return h?this.LOG_LEVEL_SEVERITY.get(d)<this.LOG_LEVEL_SEVERITY.get(h):!1},this._capabilities=u?.capabilities??{},this._instructions=u?.instructions,this._jsonSchemaValidator=u?.jsonSchemaValidator??new PU,this.setRequestHandler(Y3,(d=>this._oninitialize(d))),this.setNotificationHandler(Q3,(()=>this.oninitialized?.())),this._capabilities.logging&&this.setRequestHandler(N3,(async(d,p)=>{let h=p.sessionId||p.requestInfo?.headers["mcp-session-id"]||void 0,{level:x}=d.params,$=j9.safeParse(x);return $.success&&this._loggingLevels.set(h,$.data),{}}))}get experimental(){return this._experimental||(this._experimental={tasks:new ZU(this)}),this._experimental}registerCapabilities(t){if(this.transport)throw Error("Cannot register capabilities after connecting to transport");this._capabilities=NO(this._capabilities,t)}setRequestHandler(t,u){let d=h4(t)?.method;if(!d)throw Error("Schema is missing a method literal");let p;if(A6(d)){let h=d;p=h._zod?.def?.value??h.value}else{let h=d;p=h._def?.value??h.value}if(typeof p!="string")throw Error("Schema method literal must be a string");if(p==="tools/call"){let h=async(x,$)=>{let b=g4(x0,x);if(!b.success){let I=b.error instanceof Error?b.error.message:String(b.error);throw new g(m.InvalidParams,`Invalid tools/call request: ${I}`)}let{params:w}=b.data,j=await Promise.resolve(u(x,$));if(w.task){let I=g4(k0,j);if(!I.success){let U=I.error instanceof Error?I.error.message:String(I.error);throw new g(m.InvalidParams,`Invalid task creation result: ${U}`)}return I.data}let N=g4(HQ,j);if(!N.success){let I=N.error instanceof Error?N.error.message:String(N.error);throw new g(m.InvalidParams,`Invalid tools/call result: ${I}`)}return N.data};return super.setRequestHandler(t,h)}return super.setRequestHandler(t,u)}assertCapabilityForMethod(t){switch(t){case"sampling/createMessage":if(!this._clientCapabilities?.sampling)throw Error(`Client does not support sampling (required for ${t})`);break;case"elicitation/create":if(!this._clientCapabilities?.elicitation)throw Error(`Client does not support elicitation (required for ${t})`);break;case"roots/list":if(!this._clientCapabilities?.roots)throw Error(`Client does not support listing roots (required for ${t})`);break;case"ping":break}}assertNotificationCapability(t){switch(t){case"notifications/message":if(!this._capabilities.logging)throw Error(`Server does not support logging (required for ${t})`);break;case"notifications/resources/updated":case"notifications/resources/list_changed":if(!this._capabilities.resources)throw Error(`Server does not support notifying about resources (required for ${t})`);break;case"notifications/tools/list_changed":if(!this._capabilities.tools)throw Error(`Server does not support notifying of tool list changes (required for ${t})`);break;case"notifications/prompts/list_changed":if(!this._capabilities.prompts)throw Error(`Server does not support notifying of prompt list changes (required for ${t})`);break;case"notifications/elicitation/complete":if(!this._clientCapabilities?.elicitation?.url)throw Error(`Client does not support URL elicitation (required for ${t})`);break;case"notifications/cancelled":break;case"notifications/progress":break}}assertRequestHandlerCapability(t){if(this._capabilities)switch(t){case"completion/complete":if(!this._capabilities.completions)throw Error(`Server does not support completions (required for ${t})`);break;case"logging/setLevel":if(!this._capabilities.logging)throw Error(`Server does not support logging (required for ${t})`);break;case"prompts/get":case"prompts/list":if(!this._capabilities.prompts)throw Error(`Server does not support prompts (required for ${t})`);break;case"resources/list":case"resources/templates/list":case"resources/read":if(!this._capabilities.resources)throw Error(`Server does not support resources (required for ${t})`);break;case"tools/call":case"tools/list":if(!this._capabilities.tools)throw Error(`Server does not support tools (required for ${t})`);break;case"tasks/get":case"tasks/list":case"tasks/result":case"tasks/cancel":if(!this._capabilities.tasks)throw Error(`Server does not support tasks capability (required for ${t})`);break;case"ping":case"initialize":break}}assertTaskCapability(t){aD(this._clientCapabilities?.tasks?.requests,t,"Client")}assertTaskHandlerCapability(t){this._capabilities&&tD(this._capabilities.tasks?.requests,t,"Server")}async _oninitialize(t){let u=t.params.protocolVersion;return this._clientCapabilities=t.params.capabilities,this._clientVersion=t.params.clientInfo,{protocolVersion:wV.includes(u)?u:sG,capabilities:this.getCapabilities(),serverInfo:this._serverInfo,...this._instructions&&{instructions:this._instructions}}}getClientCapabilities(){return this._clientCapabilities}getClientVersion(){return this._clientVersion}getCapabilities(){return this._capabilities}async ping(){return this.request({method:"ping"},d7)}async createMessage(t,u){if((t.tools||t.toolChoice)&&!this._clientCapabilities?.sampling?.tools)throw Error("Client does not support sampling tools capability.");if(t.messages.length>0){let d=t.messages[t.messages.length-1],p=Array.isArray(d.content)?d.content:[d.content],h=p.some((w=>w.type==="tool_result")),x=t.messages.length>1?t.messages[t.messages.length-2]:void 0,$=x?Array.isArray(x.content)?x.content:[x.content]:[],b=$.some((w=>w.type==="tool_use"));if(h){if(p.some((w=>w.type!=="tool_result")))throw Error("The last message must contain only tool_result content if any is present");if(!b)throw Error("tool_result blocks are not matching any tool_use from the previous message")}if(b){let w=new Set($.filter((N=>N.type==="tool_use")).map((N=>N.id))),j=new Set(p.filter((N=>N.type==="tool_result")).map((N=>N.toolUseId)));if(w.size!==j.size||![...w].every((N=>j.has(N))))throw Error("ids of tool_result blocks and tool_use blocks from previous message do not match")}}return t.tools?this.request({method:"sampling/createMessage",params:t},V3,u):this.request({method:"sampling/createMessage",params:t},F9,u)}async elicitInput(t,u){switch(t.mode??"form"){case"url":{if(!this._clientCapabilities?.elicitation?.url)throw Error("Client does not support url elicitation.");let d=t;return this.request({method:"elicitation/create",params:d},T0,u)}case"form":{if(!this._clientCapabilities?.elicitation?.form)throw Error("Client does not support form elicitation.");let d=t.mode==="form"?t:{...t,mode:"form"},p=await this.request({method:"elicitation/create",params:d},T0,u);if(p.action==="accept"&&p.content&&d.requestedSchema)try{let h=this._jsonSchemaValidator.getValidator(d.requestedSchema)(p.content);if(!h.valid)throw new g(m.InvalidParams,`Elicitation response content does not match requested schema: ${h.errorMessage}`)}catch(h){throw h instanceof g?h:new g(m.InternalError,`Error validating elicitation response: ${h instanceof Error?h.message:String(h)}`)}return p}}}createElicitationCompletionNotifier(t,u){if(!this._clientCapabilities?.elicitation?.url)throw Error("Client does not support URL elicitation (required for notifications/elicitation/complete)");return()=>this.notification({method:"notifications/elicitation/complete",params:{elicitationId:t}},u)}async listRoots(t,u){return this.request({method:"roots/list",params:t},O3,u)}async sendLoggingMessage(t,u){if(this._capabilities.logging&&!this.isMessageIgnored(t.level,u))return this.notification({method:"notifications/message",params:t})}async sendResourceUpdated(t){return this.notification({method:"notifications/resources/updated",params:t})}async sendResourceListChanged(){return this.notification({method:"notifications/resources/list_changed"})}async sendToolListChanged(){return this.notification({method:"notifications/tools/list_changed"})}async sendPromptListChanged(){return this.notification({method:"notifications/prompts/list_changed"})}}var eD=Symbol.for("mcp.completable");function RU(r){return!!r&&typeof r=="object"&&eD in r}function $L(r){return r[eD]?.complete}var sD;(function(r){r.Completable="McpCompletable"})(sD||(sD={}));var Ex=/^[A-Za-z0-9._-]{1,128}$/;function Rx(r){let t=[];if(r.length===0)return{isValid:!1,warnings:["Tool name cannot be empty"]};if(r.length>128)return{isValid:!1,warnings:[`Tool name exceeds maximum length of 128 characters (current: ${r.length})`]};if(r.includes(" ")&&t.push("Tool name contains spaces, which may cause parsing issues"),r.includes(",")&&t.push("Tool name contains commas, which may cause parsing issues"),(r.startsWith("-")||r.endsWith("-"))&&t.push("Tool name starts or ends with a dash, which may cause parsing issues in some contexts"),(r.startsWith(".")||r.endsWith("."))&&t.push("Tool name starts or ends with a dot, which may cause parsing issues in some contexts"),!Ex.test(r)){let u=r.split("").filter((d=>!/[A-Za-z0-9._-]/.test(d))).filter(((d,p,h)=>h.indexOf(d)===p));return t.push(`Tool name contains invalid characters: ${u.map((d=>`"${d}"`)).join(", ")}`,"Allowed characters are: A-Z, a-z, 0-9, underscore (_), dash (-), and dot (.)"),{isValid:!1,warnings:t}}return{isValid:!0,warnings:t}}function Sx(r,t){if(t.length>0){console.warn(`Tool name validation warning for "${r}":`);for(let u of t)console.warn(` - ${u}`);console.warn("Tool registration will proceed, but this may cause compatibility issues."),console.warn("Consider updating the tool name to conform to the MCP tool naming standard."),console.warn("See SEP: Specify Format for Tool Names (https://github.com/modelcontextprotocol/modelcontextprotocol/issues/986) for more details.")}}function SU(r){let t=Rx(r);return Sx(r,t.warnings),t.isValid}class vU{constructor(t){this._mcpServer=t}registerToolTask(t,u,d){let p={taskSupport:"required",...u.execution};if(p.taskSupport==="forbidden")throw Error(`Cannot register task-based tool '${t}' with taskSupport 'forbidden'. Use registerTool() instead.`);return this._mcpServer._createRegisteredTool(t,u.title,u.description,u.inputSchema,u.outputSchema,u.annotations,p,u._meta,d)}}class kU{constructor(t,u){this._registeredResources={},this._registeredResourceTemplates={},this._registeredTools={},this._registeredPrompts={},this._toolHandlersInitialized=!1,this._completionHandlerInitialized=!1,this._resourceHandlersInitialized=!1,this._promptHandlersInitialized=!1,this.server=new EU(t,u)}get experimental(){return this._experimental||(this._experimental={tasks:new vU(this)}),this._experimental}async connect(t){return await this.server.connect(t)}async close(){await this.server.close()}setToolRequestHandlers(){this._toolHandlersInitialized||(this.server.assertCanSetRequestHandler(t4(UQ)),this.server.assertCanSetRequestHandler(t4(x0)),this.server.registerCapabilities({tools:{listChanged:!0}}),this.server.setRequestHandler(UQ,(()=>({tools:Object.entries(this._registeredTools).filter((([,t])=>t.enabled)).map((([t,u])=>{let d={name:t,title:u.title,description:u.description,inputSchema:(()=>{let p=E0(u.inputSchema);return p?j3(p,{strictUnions:!0,pipeStrategy:"input"}):vx})(),annotations:u.annotations,execution:u.execution,_meta:u._meta};if(u.outputSchema){let p=E0(u.outputSchema);p&&(d.outputSchema=j3(p,{strictUnions:!0,pipeStrategy:"output"}))}return d}))}))),this.server.setRequestHandler(x0,(async(t,u)=>{try{let d=this._registeredTools[t.params.name];if(!d)throw new g(m.InvalidParams,`Tool ${t.params.name} not found`);if(!d.enabled)throw new g(m.InvalidParams,`Tool ${t.params.name} disabled`);let p=!!t.params.task,h=d.execution?.taskSupport,x="createTask"in d.handler;if((h==="required"||h==="optional")&&!x)throw new g(m.InternalError,`Tool ${t.params.name} has taskSupport '${h}' but was not registered with registerToolTask`);if(h==="required"&&!p)throw new g(m.MethodNotFound,`Tool ${t.params.name} requires task augmentation (taskSupport: 'required')`);if(h==="optional"&&!p&&x)return await this.handleAutomaticTaskPolling(d,t,u);let $=await this.validateToolInput(d,t.params.arguments,t.params.name),b=await this.executeToolHandler(d,$,u);return p||await this.validateToolOutput(d,b,t.params.name),b}catch(d){if(d instanceof g&&d.code===m.UrlElicitationRequired)throw d;return this.createToolError(d instanceof Error?d.message:String(d))}})),this._toolHandlersInitialized=!0)}createToolError(t){return{content:[{type:"text",text:t}],isError:!0}}async validateToolInput(t,u,d){if(!t.inputSchema)return;let p=E0(t.inputSchema)??t.inputSchema,h=await R7(p,u);if(!h.success){let x="error"in h?h.error:"Unknown error",$=S7(x);throw new g(m.InvalidParams,`Input validation error: Invalid arguments for tool ${d}: ${$}`)}return h.data}async validateToolOutput(t,u,d){if(!t.outputSchema||!("content"in u)||u.isError)return;if(!u.structuredContent)throw new g(m.InvalidParams,`Output validation error: Tool ${d} has an output schema but no structured content was provided`);let p=E0(t.outputSchema),h=await R7(p,u.structuredContent);if(!h.success){let x="error"in h?h.error:"Unknown error",$=S7(x);throw new g(m.InvalidParams,`Output validation error: Invalid structured content for tool ${d}: ${$}`)}}async executeToolHandler(t,u,d){let p=t.handler;if("createTask"in p){if(!d.taskStore)throw Error("No task store provided.");let h={...d,taskStore:d.taskStore};return t.inputSchema?await Promise.resolve(p.createTask(u,h)):await Promise.resolve(p.createTask(h))}return t.inputSchema?await Promise.resolve(p(u,d)):await Promise.resolve(p(d))}async handleAutomaticTaskPolling(t,u,d){if(!d.taskStore)throw Error("No task store provided for task-capable tool.");let p=await this.validateToolInput(t,u.params.arguments,u.params.name),h=t.handler,x={...d,taskStore:d.taskStore},$=p?await Promise.resolve(h.createTask(p,x)):await Promise.resolve(h.createTask(x)),b=$.task.taskId,w=$.task,j=w.pollInterval??5e3;for(;w.status!=="completed"&&w.status!=="failed"&&w.status!=="cancelled";){await new Promise((I=>setTimeout(I,j)));let N=await d.taskStore.getTask(b);if(!N)throw new g(m.InternalError,`Task ${b} not found during polling`);w=N}return await d.taskStore.getTaskResult(b)}setCompletionRequestHandler(){this._completionHandlerInitialized||(this.server.assertCanSetRequestHandler(t4(KQ)),this.server.registerCapabilities({completions:{}}),this.server.setRequestHandler(KQ,(async t=>{switch(t.params.ref.type){case"ref/prompt":return SV(t),this.handlePromptCompletion(t,t.params.ref);case"ref/resource":return vV(t),this.handleResourceCompletion(t,t.params.ref);default:throw new g(m.InvalidParams,`Invalid completion reference: ${t.params.ref}`)}})),this._completionHandlerInitialized=!0)}async handlePromptCompletion(t,u){let d=this._registeredPrompts[u.name];if(!d)throw new g(m.InvalidParams,`Prompt ${u.name} not found`);if(!d.enabled)throw new g(m.InvalidParams,`Prompt ${u.name} disabled`);if(!d.argsSchema)return i9;let p=h4(d.argsSchema)?.[t.params.argument.name];if(!RU(p))return i9;let h=$L(p);if(!h)return i9;let x=await h(t.params.argument.value,t.params.context);return JL(x)}async handleResourceCompletion(t,u){let d=Object.values(this._registeredResourceTemplates).find((x=>x.resourceTemplate.uriTemplate.toString()===u.uri));if(!d){if(this._registeredResources[u.uri])return i9;throw new g(m.InvalidParams,`Resource template ${t.params.ref.uri} not found`)}let p=d.resourceTemplate.completeCallback(t.params.argument.name);if(!p)return i9;let h=await p(t.params.argument.value,t.params.context);return JL(h)}setResourceRequestHandlers(){this._resourceHandlersInitialized||(this.server.assertCanSetRequestHandler(t4(YQ)),this.server.assertCanSetRequestHandler(t4(QQ)),this.server.assertCanSetRequestHandler(t4(zQ)),this.server.registerCapabilities({resources:{listChanged:!0}}),this.server.setRequestHandler(YQ,(async(t,u)=>{let d=Object.entries(this._registeredResources).filter((([h,x])=>x.enabled)).map((([h,x])=>({uri:h,name:x.name,...x.metadata}))),p=[];for(let h of Object.values(this._registeredResourceTemplates)){if(!h.resourceTemplate.listCallback)continue;let x=await h.resourceTemplate.listCallback(u);for(let $ of x.resources)p.push({...h.metadata,...$})}return{resources:[...d,...p]}})),this.server.setRequestHandler(QQ,(async()=>({resourceTemplates:Object.entries(this._registeredResourceTemplates).map((([t,u])=>({name:t,uriTemplate:u.resourceTemplate.uriTemplate.toString(),...u.metadata})))}))),this.server.setRequestHandler(zQ,(async(t,u)=>{let d=new URL(t.params.uri),p=this._registeredResources[d.toString()];if(p){if(!p.enabled)throw new g(m.InvalidParams,`Resource ${d} disabled`);return p.readCallback(d,u)}for(let h of Object.values(this._registeredResourceTemplates)){let x=h.resourceTemplate.uriTemplate.match(d.toString());if(x)return h.readCallback(d,x,u)}throw new g(m.InvalidParams,`Resource ${d} not found`)})),this._resourceHandlersInitialized=!0)}setPromptRequestHandlers(){this._promptHandlersInitialized||(this.server.assertCanSetRequestHandler(t4(WQ)),this.server.assertCanSetRequestHandler(t4(GQ)),this.server.registerCapabilities({prompts:{listChanged:!0}}),this.server.setRequestHandler(WQ,(()=>({prompts:Object.entries(this._registeredPrompts).filter((([,t])=>t.enabled)).map((([t,u])=>({name:t,title:u.title,description:u.description,arguments:u.argsSchema?kx(u.argsSchema):void 0})))}))),this.server.setRequestHandler(GQ,(async(t,u)=>{let d=this._registeredPrompts[t.params.name];if(!d)throw new g(m.InvalidParams,`Prompt ${t.params.name} not found`);if(!d.enabled)throw new g(m.InvalidParams,`Prompt ${t.params.name} disabled`);if(d.argsSchema){let p=E0(d.argsSchema),h=await R7(p,t.params.arguments);if(!h.success){let b="error"in h?h.error:"Unknown error",w=S7(b);throw new g(m.InvalidParams,`Invalid arguments for prompt ${t.params.name}: ${w}`)}let x=h.data,$=d.callback;return await Promise.resolve($(x,u))}else{let p=d.callback;return await Promise.resolve(p(u))}})),this._promptHandlersInitialized=!0)}resource(t,u,...d){let p;typeof d[0]=="object"&&(p=d.shift());let h=d[0];if(typeof u=="string"){if(this._registeredResources[u])throw Error(`Resource ${u} is already registered`);let x=this._createRegisteredResource(t,void 0,u,p,h);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),x}else{if(this._registeredResourceTemplates[t])throw Error(`Resource template ${t} is already registered`);let x=this._createRegisteredResourceTemplate(t,void 0,u,p,h);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),x}}registerResource(t,u,d,p){if(typeof u=="string"){if(this._registeredResources[u])throw Error(`Resource ${u} is already registered`);let h=this._createRegisteredResource(t,d.title,u,d,p);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),h}else{if(this._registeredResourceTemplates[t])throw Error(`Resource template ${t} is already registered`);let h=this._createRegisteredResourceTemplate(t,d.title,u,d,p);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),h}}_createRegisteredResource(t,u,d,p,h){let x={name:t,title:u,metadata:p,readCallback:h,enabled:!0,disable:()=>x.update({enabled:!1}),enable:()=>x.update({enabled:!0}),remove:()=>x.update({uri:null}),update:$=>{typeof $.uri<"u"&&$.uri!==d&&(delete this._registeredResources[d],$.uri&&(this._registeredResources[$.uri]=x)),typeof $.name<"u"&&(x.name=$.name),typeof $.title<"u"&&(x.title=$.title),typeof $.metadata<"u"&&(x.metadata=$.metadata),typeof $.callback<"u"&&(x.readCallback=$.callback),typeof $.enabled<"u"&&(x.enabled=$.enabled),this.sendResourceListChanged()}};return this._registeredResources[d]=x,x}_createRegisteredResourceTemplate(t,u,d,p,h){let x={resourceTemplate:d,title:u,metadata:p,readCallback:h,enabled:!0,disable:()=>x.update({enabled:!1}),enable:()=>x.update({enabled:!0}),remove:()=>x.update({name:null}),update:b=>{typeof b.name<"u"&&b.name!==t&&(delete this._registeredResourceTemplates[t],b.name&&(this._registeredResourceTemplates[b.name]=x)),typeof b.title<"u"&&(x.title=b.title),typeof b.template<"u"&&(x.resourceTemplate=b.template),typeof b.metadata<"u"&&(x.metadata=b.metadata),typeof b.callback<"u"&&(x.readCallback=b.callback),typeof b.enabled<"u"&&(x.enabled=b.enabled),this.sendResourceListChanged()}};this._registeredResourceTemplates[t]=x;let $=d.uriTemplate.variableNames;return Array.isArray($)&&$.some((b=>!!d.completeCallback(b)))&&this.setCompletionRequestHandler(),x}_createRegisteredPrompt(t,u,d,p,h){let x={title:u,description:d,argsSchema:p===void 0?void 0:Z1(p),callback:h,enabled:!0,disable:()=>x.update({enabled:!1}),enable:()=>x.update({enabled:!0}),remove:()=>x.update({name:null}),update:$=>{typeof $.name<"u"&&$.name!==t&&(delete this._registeredPrompts[t],$.name&&(this._registeredPrompts[$.name]=x)),typeof $.title<"u"&&(x.title=$.title),typeof $.description<"u"&&(x.description=$.description),typeof $.argsSchema<"u"&&(x.argsSchema=Z1($.argsSchema)),typeof $.callback<"u"&&(x.callback=$.callback),typeof $.enabled<"u"&&(x.enabled=$.enabled),this.sendPromptListChanged()}};return this._registeredPrompts[t]=x,p&&Object.values(p).some(($=>{let b=$ instanceof M6?$._def?.innerType:$;return RU(b)}))&&this.setCompletionRequestHandler(),x}_createRegisteredTool(t,u,d,p,h,x,$,b,w){SU(t);let j={title:u,description:d,inputSchema:XL(p),outputSchema:XL(h),annotations:x,execution:$,_meta:b,handler:w,enabled:!0,disable:()=>j.update({enabled:!1}),enable:()=>j.update({enabled:!0}),remove:()=>j.update({name:null}),update:N=>{typeof N.name<"u"&&N.name!==t&&(typeof N.name=="string"&&SU(N.name),delete this._registeredTools[t],N.name&&(this._registeredTools[N.name]=j)),typeof N.title<"u"&&(j.title=N.title),typeof N.description<"u"&&(j.description=N.description),typeof N.paramsSchema<"u"&&(j.inputSchema=Z1(N.paramsSchema)),typeof N.outputSchema<"u"&&(j.outputSchema=Z1(N.outputSchema)),typeof N.callback<"u"&&(j.handler=N.callback),typeof N.annotations<"u"&&(j.annotations=N.annotations),typeof N._meta<"u"&&(j._meta=N._meta),typeof N.enabled<"u"&&(j.enabled=N.enabled),this.sendToolListChanged()}};return this._registeredTools[t]=j,this.setToolRequestHandlers(),this.sendToolListChanged(),j}tool(t,...u){if(this._registeredTools[t])throw Error(`Tool ${t} is already registered`);let d,p,h,x;if(typeof u[0]=="string"&&(d=u.shift()),u.length>1){let b=u[0];CU(b)?(p=u.shift(),u.length>1&&typeof u[0]=="object"&&u[0]!==null&&!CU(u[0])&&(x=u.shift())):typeof b=="object"&&b!==null&&(x=u.shift())}let $=u[0];return this._createRegisteredTool(t,void 0,d,p,h,x,{taskSupport:"forbidden"},void 0,$)}registerTool(t,u,d){if(this._registeredTools[t])throw Error(`Tool ${t} is already registered`);let{title:p,description:h,inputSchema:x,outputSchema:$,annotations:b,_meta:w}=u;return this._createRegisteredTool(t,p,h,x,$,b,{taskSupport:"forbidden"},w,d)}prompt(t,...u){if(this._registeredPrompts[t])throw Error(`Prompt ${t} is already registered`);let d;typeof u[0]=="string"&&(d=u.shift());let p;u.length>1&&(p=u.shift());let h=u[0],x=this._createRegisteredPrompt(t,void 0,d,p,h);return this.setPromptRequestHandlers(),this.sendPromptListChanged(),x}registerPrompt(t,u,d){if(this._registeredPrompts[t])throw Error(`Prompt ${t} is already registered`);let{title:p,description:h,argsSchema:x}=u,$=this._createRegisteredPrompt(t,p,h,x,d);return this.setPromptRequestHandlers(),this.sendPromptListChanged(),$}isConnected(){return this.server.transport!==void 0}async sendLoggingMessage(t,u){return this.server.sendLoggingMessage(t,u)}sendResourceListChanged(){this.isConnected()&&this.server.sendResourceListChanged()}sendToolListChanged(){this.isConnected()&&this.server.sendToolListChanged()}sendPromptListChanged(){this.isConnected()&&this.server.sendPromptListChanged()}}var vx={type:"object",properties:{}};function YL(r){return r!==null&&typeof r=="object"&&"parse"in r&&typeof r.parse=="function"&&"safeParse"in r&&typeof r.safeParse=="function"}function Cx(r){return"_def"in r||"_zod"in r||YL(r)}function CU(r){return typeof r!="object"||r===null||Cx(r)?!1:Object.keys(r).length===0?!0:Object.values(r).some(YL)}function XL(r){if(r)return CU(r)?Z1(r):r}function kx(r){let t=h4(r);return t?Object.entries(t).map((([u,d])=>{let p=SN(d),h=vN(d);return{name:u,description:p,required:!h}})):[]}function t4(r){let t=h4(r)?.method;if(!t)throw Error("Schema is missing a method literal");let u=v7(t);if(typeof u=="string")return u;throw Error("Schema method literal must be a string")}function JL(r){return{completion:{values:r.slice(0,100),total:r.length,hasMore:r.length>100}}}var i9={completion:{values:[],hasMore:!1}};function _x(r,t,u,d,p){let h={};return p?.searchHint&&(h["anthropic/searchHint"]=p.searchHint),p?.alwaysLoad&&(h["anthropic/alwaysLoad"]=!0),{name:r,description:t,inputSchema:u,handler:d,annotations:p?.annotations,_meta:Object.keys(h).length>0?h:void 0}}function xx(r){let t=new kU({name:r.name,version:r.version??"1.0.0"},{capabilities:{tools:r.tools?{}:void 0}});return r.tools&&r.tools.forEach((u=>{for(let d of Object.values(u.inputSchema)){if(!Tx(d))continue;let p=d.description;p&&!X6.has(d)&&X6.add(d,{description:p})}t.registerTool(u.name,{description:u.description,inputSchema:u.inputSchema,annotations:u.annotations,_meta:u._meta},u.handler)})),{type:"sdk",name:r.name,instance:t}}function Tx(r){return typeof r=="object"&&r!==null&&"_zod"in r}function QL(r){let t;return()=>t??=r()}var zL=15e3,yx=QL((()=>u4.object({session_id:u4.string(),ws_url:u4.string(),work_dir:u4.string().optional(),session_key:u4.string().optional()})));class r6 extends Error{constructor(t){super(t),this.name="DirectConnectError"}}class GL{options;ws;sessionId;workDir;abortController;readyState=!1;closed=!1;exitError;messages=new K1;readyPromise;readyResolve;readyReject;abortHandler;partialChunks=[];constructor(t){this.options=t,this.abortController=t.abortController??new AbortController,this.readyPromise=new Promise(((u,d)=>{this.readyResolve=u,this.readyReject=d})),this.readyPromise.catch((()=>{})),this.initialize()}get ready(){return this.readyPromise}getSessionId(){return this.sessionId}getWorkDir(){return this.workDir}async initialize(){if(this.abortController.signal.aborted){this.failInit(new a$("Connection aborted"));return}this.abortHandler=()=>{this.close(),this.exitError=new a$("Connection aborted by user")},this.abortController.signal.addEventListener("abort",this.abortHandler);let t;try{let h=await gx(this.options);this.sessionId=h.sessionId,this.workDir=h.workDir,t=h.wsUrl}catch(h){this.failInit(NK(h));return}if(this.closed){this.options.deleteSessionOnClose&&this.sessionId&&WL(this.options.serverUrl,this.sessionId,this.options.authToken);return}let u={};this.options.authToken&&(u.authorization=`Bearer ${this.options.authToken}`);let d=new WebSocket(t,{headers:u});this.ws=d;let p=setTimeout(((h,x)=>{if(!h.readyState){x.close();let $=new r6(`WebSocket connection timeout after ${zL}ms`);h.exitError=$,h.readyReject?.($)}}),zL,this,d);d.addEventListener("open",(()=>{clearTimeout(p),this.readyState=!0,s$(`[DirectConnectTransport] Connected to ${this.options.serverUrl}, session=${this.sessionId}`),this.readyResolve?.()})),d.addEventListener("message",(h=>{let x=typeof h.data=="string"?h.data:"";if(x.indexOf(`
462
462
  `)===-1){x&&this.partialChunks.push(x);return}let $=this.partialChunks.join("")+x;this.partialChunks.length=0;let b=$.split(`
463
463
  `),w=b.pop()??"";w&&this.partialChunks.push(w);for(let j of b){if(!j)continue;let N;try{N=j6(j)}catch(I){s$(`DirectConnect: dropped malformed JSON line (${j.length} bytes): ${I}`);continue}this.messages.enqueue(N)}})),d.addEventListener("error",(()=>{clearTimeout(p);let h=new r6("WebSocket connection error");this.exitError=h,this.readyReject?.(h),this.messages.done()})),d.addEventListener("close",(h=>{this.readyState=!1,this.closed=!0,h.code!==1e3&&h.code!==1001&&!this.exitError&&(this.exitError=new r6(`WebSocket closed abnormally: ${h.code} ${h.reason}`)),this.messages.done()}))}failInit(t){this.exitError=t,this.closed=!0,this.readyReject?.(t),this.messages.done()}async write(t){if(this.abortController.signal.aborted)throw new a$("Operation aborted");if(this.readyState||await this.readyPromise,!this.ws||this.ws.readyState!==WebSocket.OPEN)throw new r6("Transport is not ready for writing");this.ws.send(t)}isReady(){return this.readyState&&this.ws?.readyState===WebSocket.OPEN}endInput(){}close(){this.closed||(this.closed=!0,this.readyState=!1,this.abortHandler&&(this.abortController.signal.removeEventListener("abort",this.abortHandler),this.abortHandler=void 0),this.abortController.signal.aborted||this.abortController.abort(),this.ws&&this.ws.readyState===WebSocket.OPEN&&this.ws.close(1e3,"Normal closure"),this.messages.done(),this.options.deleteSessionOnClose&&this.sessionId&&WL(this.options.serverUrl,this.sessionId,this.options.authToken))}async*readMessages(){if(yield*this.messages,this.exitError)throw this.exitError}}function fx(r){if(r.startsWith("cc://")){let d=r.slice(5),p=new URL(`http://${d}`),h=p.pathname.slice(1)||void 0;return{serverUrl:`http://${p.host}`,authToken:h}}if(r.startsWith("cc+unix://"))throw new r6("Unix socket connect (cc+unix://) is not supported by the SDK transport");let t=/^https?:\/\//i.test(r)?r:`http://${r}`,u=new URL(t);return{serverUrl:`${u.protocol}//${u.host}`,authToken:void 0}}async function gx(r){let t={"content-type":"application/json"};r.authToken&&(t.authorization=`Bearer ${r.authToken}`);let u={};r.cwd&&(u.cwd=r.cwd),r.sessionKey&&(u.session_key=r.sessionKey),r.permissionMode&&(u.permission_mode=r.permissionMode);let d;try{d=await fetch(`${r.serverUrl}/sessions`,{method:"POST",headers:t,body:q$(u)})}catch(h){throw new r6(`Failed to connect to server at ${r.serverUrl}: ${h instanceof Error?h.message:String(h)}`)}if(!d.ok){let h=await d.text().catch((()=>""));throw new r6(`Failed to create session: ${d.status} ${d.statusText}${h?` \u2014 ${h}`:""}`)}let p=yx().safeParse(await d.json());if(!p.success)throw new r6(`Invalid session response: ${p.error.message}`);return{sessionId:p.data.session_id,wsUrl:p.data.ws_url,workDir:p.data.work_dir}}async function WL(r,t,u){let d={};u&&(d.authorization=`Bearer ${u}`);try{await fetch(`${r}/sessions/${t}`,{method:"DELETE",headers:d})}catch{}}function HL(r,t){let{systemPrompt:u,settings:d,settingSources:p,sandbox:h,...x}=r??{},$,b;u===void 0?$="":typeof u=="string"?$=u:u.type==="preset"&&(b=u.append);let w=x.pathToClaudeCodeExecutable;if(!w){let De=(0,external_url_.fileURLToPath)(import.meta.url),ze=(0,external_path_.join)(De,"..");w=(0,external_path_.join)(ze,"cli.js")}process.env.CLAUDE_AGENT_SDK_VERSION="0.2.92";let{abortController:j=y1(),additionalDirectories:N=[],agent:I,agents:U,allowedTools:z=[],betas:O,canUseTool:B,continue:L,cwd:W,debug:H,debugFile:V,disallowedTools:J=[],tools:G,env:X,executable:K=f1()?"bun":"node",executableArgs:Y=[],extraArgs:ee={},fallbackModel:Q,enableFileCheckpointing:ie,toolConfig:ae,forkSession:ne,hooks:te,includeHookEvents:oe,includePartialMessages:de,onElicitation:ke,persistSession:xe,thinking:_e,effort:se,maxThinkingTokens:ye,maxTurns:fe,maxBudgetUsd:re,taskBudget:ce,mcpServers:he,model:ve,outputFormat:je,permissionMode:Ce="default",allowDangerouslySkipPermissions:ge=!1,permissionPromptToolName:be,plugins:pe,workload:me,resume:Se,resumeSessionAt:le,sessionId:ue,stderr:$e,strictMcpConfig:Ie}=x,Re=je?.type==="json_schema"?je.schema:void 0,we=X;we||(we={...process.env}),we.CLAUDE_CODE_ENTRYPOINT||(we.CLAUDE_CODE_ENTRYPOINT="sdk-ts"),ie&&(we.CLAUDE_CODE_ENABLE_SDK_FILE_CHECKPOINTING="true"),ae?.askUserQuestion?.previewFormat&&(we.CLAUDE_CODE_QUESTION_PREVIEW_FORMAT=ae.askUserQuestion.previewFormat);let Ee={},Oe=new Map;if(he)for(let[De,ze]of Object.entries(he))ze.type==="sdk"&&ze.instance?Oe.set(De,ze.instance):Ee[De]=ze;let Ne;if(_e)switch(_e.type){case"adaptive":Ne={type:"adaptive"};break;case"enabled":Ne={type:"enabled",budgetTokens:_e.budgetTokens};break;case"disabled":Ne={type:"disabled"};break}else ye!==void 0&&(Ne=ye===0?{type:"disabled"}:{type:"enabled",budgetTokens:ye});let Ae=new cX({abortController:j,additionalDirectories:N,agent:I,betas:O,cwd:W,debug:H,debugFile:V,executable:K,executableArgs:Y,extraArgs:me?{...ee,workload:me}:ee,pathToClaudeCodeExecutable:w,env:we,forkSession:ne,stderr:$e,thinkingConfig:Ne,effort:se,maxTurns:fe,maxBudgetUsd:re,taskBudget:ce,model:ve,fallbackModel:Q,jsonSchema:Re,permissionMode:Ce,allowDangerouslySkipPermissions:ge,permissionPromptToolName:be,continueConversation:L,resume:Se,resumeSessionAt:le,sessionId:ue,settings:typeof d=="object"?q$(d):d,settingSources:p,allowedTools:z,disallowedTools:J,tools:G,mcpServers:Ee,strictMcpConfig:Ie,canUseTool:!!B,hooks:!!te,includeHookEvents:oe,includePartialMessages:de,persistSession:xe,plugins:pe,sandbox:h,spawnClaudeCodeProcess:x.spawnClaudeCodeProcess}),qe={systemPrompt:$,appendSystemPrompt:b,agents:U,promptSuggestions:x.promptSuggestions,agentProgressSummaries:x.agentProgressSummaries};return{queryInstance:new pX(Ae,t,B,te,j,Oe,Re,qe,ke),transport:Ae,abortController:j}}function KL(r,t,u,d){typeof u=="string"?t.write(q$({type:"user",session_id:"",message:{role:"user",content:[{type:"text",text:u}]},parent_tool_use_id:null})+`
464
- `):r.streamInput(u).catch((p=>d.abort(p)))}function Qs({prompt:r,options:t}){let{queryInstance:u,transport:d,abortController:p}=HL(t,typeof r=="string");return KL(u,d,r,p),u}async function zs({options:r}={}){let{queryInstance:t,transport:u,abortController:d}=HL(r,!1);try{await t.initializationResult()}catch(x){throw t.close(),x}let p=!1;function h(){p||(p=!0,t.close())}return{query(x){if(p)throw Error("WarmQuery.query() can only be called once");p=!0;try{KL(t,u,x,d)}catch($){throw t.close(),$}return typeof x=="string"&&t.setIsSingleUserTurn(!0),t},close:h,async[Symbol.asyncDispose](){p||h()}}}function Ws(r){return hz(r)}function Gs(r,t){return CK(r,t)}async function Us(r,t){let u=[];try{const x=N$(u,hz(t),1);await x.send(r);for await(let $ of x.stream())if($.type==="result")return $;throw Error("Session ended without result message")}catch(x){var d=x,p=1}finally{var h=V$(u,d,p);h&&await h}}async function Hs(r,t){return gK(r,t)}async function Ks(r){return uK(r)}async function Ns(r,t){return mK(r,t)}async function Vs(r,t,u){return cK(r,t,u)}async function Os(r,t,u){return pK(r,t,u)}async function ws(r,t){return dK(r,t)}async function Bs(r,t){return tK(r,t)}async function qs(r,t,u){return aK(r,t,u)}const __agent_dirname=(0,external_path_.dirname)((0,external_url_.fileURLToPath)(import.meta.url)),_require=(0,external_module_namespaceObject.createRequire)(import.meta.url);let _claudeCodePath;try{const r=_require.resolve("@anthropic-ai/claude-agent-sdk");_claudeCodePath=(0,external_path_.join)((0,external_path_.dirname)(r),"cli.js"),(0,external_fs_.existsSync)(_claudeCodePath)||(_claudeCodePath=void 0)}catch{_claudeCodePath=void 0}class AgentSession extends external_events_.EventEmitter{constructor(t,u={}){super(),this.id=t,this.createdAt=new Date().toISOString(),this.title=u.title||"claude",this.cwd=u.cwd||process.env.ZIHI_CWD||process.cwd(),this.permissionMode=u.permissionMode||"default",this.owner=u.owner||null,this.userDir=u.userDir||null,this.claudeSessionId=u.resumeSessionId||null,this.mode="agent",this.alive=!0,this._viewers=new Set,this._viewerNames=new Map,this.controlHolder=null,this.controlHolderName=null,this.lastInputTime=null,this._busy=!1,this._abortController=null,this._pendingPermissions=new Map,this._autoApproveTools=new Set,this._history=[],this._usage={totalCostUSD:0,totalInputTokens:0,totalOutputTokens:0,totalCacheReadTokens:0,totalCacheCreationTokens:0,queryCount:0,rateLimitInfo:null,modelUsage:{},lastInputTokens:0},this.claudeSessionId&&this._loadResumedHistory()}async query(t){if(this._busy){this.emit("agent:error",{message:"\u6B63\u5728\u5904\u7406\u4E2D\uFF0C\u8BF7\u7B49\u5F85\u5B8C\u6210"});return}this._busy=!0,this.emit("agent:busy",!0),this._history.push({type:"user",content:t,timestamp:Date.now()}),this._abortController=new AbortController;try{const u={cwd:this.cwd,permissionMode:this.permissionMode,abortController:this._abortController,..._claudeCodePath&&{pathToClaudeCodeExecutable:_claudeCodePath}};this.permissionMode!=="bypassPermissions"?u.canUseTool=(d,p,h)=>this._handlePermission(d,p,h):this.userDir&&(u.canUseTool=(d,p)=>{for(const h of this._extractPaths(d,p))if(!this._isPathAllowed(h))return this.emit("agent:message",{type:"system",content:`[\u8DEF\u5F84\u9650\u5236] ${d} \u76EE\u6807\u4E0D\u5728\u5F53\u524D\u9879\u76EE\u76EE\u5F55\u5185\uFF0C\u5DF2\u8DF3\u8FC7`}),{behavior:"deny",message:"\u8BE5\u8DEF\u5F84\u4E0D\u5728\u5F53\u524D\u9879\u76EE\u76EE\u5F55\u5185\uFF0C\u8BF7\u6539\u7528\u9879\u76EE\u76EE\u5F55\u4E0B\u7684\u8DEF\u5F84\u3002\u4F60\u4ECD\u7136\u53EF\u4EE5\u6B63\u5E38\u8BFB\u5199\u9879\u76EE\u76EE\u5F55\u5185\u7684\u4EFB\u4F55\u6587\u4EF6\u3002"};return d==="Bash"&&p?.command&&!this._isBashCommandSafe(p.command)?(this.emit("agent:message",{type:"system",content:"[\u8DEF\u5F84\u9650\u5236] Bash \u547D\u4EE4\u5F15\u7528\u4E86\u9879\u76EE\u5916\u8DEF\u5F84\uFF0C\u5DF2\u8DF3\u8FC7"}),{behavior:"deny",message:"\u547D\u4EE4\u4E2D\u5305\u542B\u9879\u76EE\u76EE\u5F55\u5916\u7684\u8DEF\u5F84\uFF0C\u8BF7\u53EA\u4F7F\u7528\u9879\u76EE\u76EE\u5F55\u5185\u7684\u8DEF\u5F84\u3002\u4F60\u4ECD\u7136\u53EF\u4EE5\u6B63\u5E38\u6267\u884C\u5176\u4ED6\u547D\u4EE4\u3002"}):{behavior:"allow"}}),this.claudeSessionId&&(u.resume=this.claudeSessionId);for await(const d of Qs({prompt:t,options:u}))this._processMessage(d)}catch(u){u.name!=="AbortError"&&this.emit("agent:error",{message:u.message})}finally{this._busy=!1,this._abortController=null,this.emit("agent:busy",!1)}}_processMessage(t){const u=!!this.claudeSessionId;t.session_id&&!this.claudeSessionId&&(this.claudeSessionId=t.session_id),t.type==="system"&&t.subtype==="init"&&t.session_id&&(this.claudeSessionId=t.session_id),!u&&this.claudeSessionId&&this.emit("session-id",this.claudeSessionId);const d={...t,timestamp:Date.now()};if(JSON.stringify(d).length>10240&&(d._truncated=!0),this._history.push(d),this._history.length>500&&(this._history=this._history.slice(-500)),this.emit("agent:message",t),t.type==="rate_limit_event"&&t.rate_limit_info&&(this._usage.rateLimitInfo=t.rate_limit_info),t.type==="result"){if(this._usage.queryCount++,t.total_cost_usd&&(this._usage.totalCostUSD+=t.total_cost_usd),t.usage){this._usage.totalInputTokens+=t.usage.input_tokens||0,this._usage.totalOutputTokens+=t.usage.output_tokens||0,this._usage.totalCacheReadTokens+=t.usage.cache_read_input_tokens||0,this._usage.totalCacheCreationTokens+=t.usage.cache_creation_input_tokens||0;const h=(t.usage.input_tokens||0)+(t.usage.cache_read_input_tokens||0);h>0&&(this._usage.lastInputTokens=h)}if(t.modelUsage)for(const[h,x]of Object.entries(t.modelUsage))this._usage.modelUsage[h]||(this._usage.modelUsage[h]={inputTokens:0,outputTokens:0,costUSD:0}),this._usage.modelUsage[h].inputTokens+=x.inputTokens||0,this._usage.modelUsage[h].outputTokens+=x.outputTokens||0,this._usage.modelUsage[h].costUSD+=x.costUSD||0}}_isPathAllowed(t){if(!this.userDir||!t)return!0;const u=(0,external_path_.resolve)((0,external_path_.normalize)(this.userDir)),d=(0,external_path_.resolve)((0,external_path_.normalize)(this.cwd),(0,external_path_.normalize)(t));return d===u||d.startsWith(u+external_path_.sep)}_extractPaths(t,u){if(!u)return[];const d=[];return u.file_path&&d.push(u.file_path),u.path&&d.push(u.path),d}_isBashCommandSafe(t){if(!this.userDir||!t)return!0;const u=(0,external_path_.resolve)((0,external_path_.normalize)(this.userDir)),d=process.platform==="win32"?/[A-Za-z]:[\\\/]/g:/(?:^|[\s;|&`"'(])\/(?!dev\/null)/g;if(!t.match(d))return!0;const h=process.platform==="win32"?t.match(/[A-Za-z]:[\\\/][^\s;|&`"')}\]>]*/g)||[]:t.match(/\/[^\s;|&`"')}\]>]*/g)||[];for(const x of h){const $=(0,external_path_.resolve)((0,external_path_.normalize)(x));if($!==u&&!$.startsWith(u+external_path_.sep))return!1}return!0}async _handlePermission(t,u,d){for(const h of this._extractPaths(t,u))if(!this._isPathAllowed(h))return this.emit("agent:message",{type:"system",content:`[\u8DEF\u5F84\u9650\u5236] ${t} \u76EE\u6807 ${h} \u4E0D\u5728\u5F53\u524D\u9879\u76EE\u76EE\u5F55\u5185\uFF0C\u5DF2\u8DF3\u8FC7`}),{behavior:"deny",message:"\u8BE5\u8DEF\u5F84\u4E0D\u5728\u5F53\u524D\u9879\u76EE\u76EE\u5F55\u5185\uFF0C\u8BF7\u6539\u7528\u9879\u76EE\u76EE\u5F55\u4E0B\u7684\u8DEF\u5F84\u3002\u4F60\u4ECD\u7136\u53EF\u4EE5\u6B63\u5E38\u8BFB\u5199\u9879\u76EE\u76EE\u5F55\u5185\u7684\u4EFB\u4F55\u6587\u4EF6\u3002"};if(t==="Bash"&&u?.command&&!this._isBashCommandSafe(u.command))return this.emit("agent:message",{type:"system",content:"[\u8DEF\u5F84\u9650\u5236] Bash \u547D\u4EE4\u5F15\u7528\u4E86\u9879\u76EE\u5916\u8DEF\u5F84\uFF0C\u5DF2\u8DF3\u8FC7"}),{behavior:"deny",message:"\u547D\u4EE4\u4E2D\u5305\u542B\u9879\u76EE\u76EE\u5F55\u5916\u7684\u8DEF\u5F84\uFF0C\u8BF7\u53EA\u4F7F\u7528\u9879\u76EE\u76EE\u5F55\u5185\u7684\u8DEF\u5F84\u3002\u4F60\u4ECD\u7136\u53EF\u4EE5\u6B63\u5E38\u6267\u884C\u5176\u4ED6\u547D\u4EE4\u3002"};if(this._autoApproveTools.has(t)||this._autoApproveTools.has("*"))return{behavior:"allow"};const p=(0,external_crypto_.randomUUID)();return this.emit("agent:message",{type:"control_request",request_id:p,request:{tool_name:t,input:u}}),new Promise((h=>{this._pendingPermissions.set(p,h)}))}respondPermission(t,u,d,p){const h=this._pendingPermissions.get(t);h&&(this._pendingPermissions.delete(t),u?(p&&d?this._autoApproveTools.add(d):p&&!d&&this._autoApproveTools.add("*"),h({behavior:"allow"})):h({behavior:"deny",message:"\u7528\u6237\u62D2\u7EDD"}))}setPermissionMode(t){this.permissionMode=t}interrupt(){this._abortController&&this._abortController.abort();for(const[,t]of this._pendingPermissions)t({behavior:"deny",message:"\u5DF2\u4E2D\u65AD"});this._pendingPermissions.clear(),this.emit("agent:message",{type:"system",subtype:"interrupted",message:"\u67E5\u8BE2\u5DF2\u4E2D\u65AD"})}kill(){this.alive=!1,this.interrupt()}_loadResumedHistory(){try{const t=(0,external_path_.join)((0,external_os_.homedir)(),".claude","projects");if(!(0,external_fs_.existsSync)(t))return;for(const u of(0,external_fs_.readdirSync)(t,{withFileTypes:!0})){if(!u.isDirectory())continue;const d=(0,external_path_.join)(t,u.name,this.claudeSessionId+".jsonl");if(!(0,external_fs_.existsSync)(d))continue;const h=(0,external_fs_.readFileSync)(d,"utf8").split(`
464
+ `):r.streamInput(u).catch((p=>d.abort(p)))}function Qs({prompt:r,options:t}){let{queryInstance:u,transport:d,abortController:p}=HL(t,typeof r=="string");return KL(u,d,r,p),u}async function zs({options:r}={}){let{queryInstance:t,transport:u,abortController:d}=HL(r,!1);try{await t.initializationResult()}catch(x){throw t.close(),x}let p=!1;function h(){p||(p=!0,t.close())}return{query(x){if(p)throw Error("WarmQuery.query() can only be called once");p=!0;try{KL(t,u,x,d)}catch($){throw t.close(),$}return typeof x=="string"&&t.setIsSingleUserTurn(!0),t},close:h,async[Symbol.asyncDispose](){p||h()}}}function Ws(r){return hz(r)}function Gs(r,t){return CK(r,t)}async function Us(r,t){let u=[];try{const x=N$(u,hz(t),1);await x.send(r);for await(let $ of x.stream())if($.type==="result")return $;throw Error("Session ended without result message")}catch(x){var d=x,p=1}finally{var h=V$(u,d,p);h&&await h}}async function Hs(r,t){return gK(r,t)}async function Ks(r){return uK(r)}async function Ns(r,t){return mK(r,t)}async function Vs(r,t,u){return cK(r,t,u)}async function Os(r,t,u){return pK(r,t,u)}async function ws(r,t){return dK(r,t)}async function Bs(r,t){return tK(r,t)}async function qs(r,t,u){return aK(r,t,u)}const __agent_dirname=(0,external_path_.dirname)((0,external_url_.fileURLToPath)(import.meta.url)),_require=(0,external_module_namespaceObject.createRequire)(import.meta.url);let _claudeCodePath;try{const r=_require.resolve("@anthropic-ai/claude-agent-sdk");_claudeCodePath=(0,external_path_.join)((0,external_path_.dirname)(r),"cli.js"),(0,external_fs_.existsSync)(_claudeCodePath)||(_claudeCodePath=void 0)}catch{_claudeCodePath=void 0}class AgentSession extends external_events_.EventEmitter{constructor(t,u={}){super(),this.id=t,this.createdAt=new Date().toISOString(),this.title=u.title||"claude",this.cwd=u.cwd||process.env.ZIHI_CWD||process.cwd(),this.permissionMode=u.permissionMode||"default",this.owner=u.owner||null,this.userDir=u.userDir||null,this.claudeSessionId=u.resumeSessionId||null,this.mode="agent",this.alive=!0,this._viewers=new Set,this._viewerNames=new Map,this.controlHolder=null,this.controlHolderName=null,this.lastInputTime=null,this._busy=!1,this._abortController=null,this._pendingPermissions=new Map,this._autoApproveTools=new Set,this._history=[],this._usage={totalCostUSD:0,totalInputTokens:0,totalOutputTokens:0,totalCacheReadTokens:0,totalCacheCreationTokens:0,queryCount:0,rateLimitInfo:null,modelUsage:{},lastInputTokens:0},this.claudeSessionId&&this._loadResumedHistory()}async query(t){if(this._busy){this.emit("agent:error",{message:"\u6B63\u5728\u5904\u7406\u4E2D\uFF0C\u8BF7\u7B49\u5F85\u5B8C\u6210"});return}this._busy=!0,this.emit("agent:busy",!0),this._history.push({type:"user",content:t,timestamp:Date.now()}),this._abortController=new AbortController;try{const u=this.userDir&&this.permissionMode==="default"?"acceptEdits":this.permissionMode,d={cwd:this.cwd,permissionMode:u,abortController:this._abortController,..._claudeCodePath&&{pathToClaudeCodeExecutable:_claudeCodePath}};this.permissionMode!=="bypassPermissions"?d.canUseTool=(p,h,x)=>this._handlePermission(p,h,x):this.userDir&&(d.canUseTool=(p,h)=>{for(const x of this._extractPaths(p,h))if(!this._isPathAllowed(x))return this.emit("agent:message",{type:"system",content:`[\u8DEF\u5F84\u9650\u5236] ${p} \u76EE\u6807\u4E0D\u5728\u5F53\u524D\u9879\u76EE\u76EE\u5F55\u5185\uFF0C\u5DF2\u8DF3\u8FC7`}),{behavior:"deny",message:"\u8BE5\u8DEF\u5F84\u4E0D\u5728\u5F53\u524D\u9879\u76EE\u76EE\u5F55\u5185\uFF0C\u8BF7\u6539\u7528\u9879\u76EE\u76EE\u5F55\u4E0B\u7684\u8DEF\u5F84\u3002\u4F60\u4ECD\u7136\u53EF\u4EE5\u6B63\u5E38\u8BFB\u5199\u9879\u76EE\u76EE\u5F55\u5185\u7684\u4EFB\u4F55\u6587\u4EF6\u3002"};return p==="Bash"&&h?.command&&!this._isBashCommandSafe(h.command)?(this.emit("agent:message",{type:"system",content:"[\u8DEF\u5F84\u9650\u5236] Bash \u547D\u4EE4\u5F15\u7528\u4E86\u9879\u76EE\u5916\u8DEF\u5F84\uFF0C\u5DF2\u8DF3\u8FC7"}),{behavior:"deny",message:"\u547D\u4EE4\u4E2D\u5305\u542B\u9879\u76EE\u76EE\u5F55\u5916\u7684\u8DEF\u5F84\uFF0C\u8BF7\u53EA\u4F7F\u7528\u9879\u76EE\u76EE\u5F55\u5185\u7684\u8DEF\u5F84\u3002\u4F60\u4ECD\u7136\u53EF\u4EE5\u6B63\u5E38\u6267\u884C\u5176\u4ED6\u547D\u4EE4\u3002"}):{behavior:"allow"}}),this.claudeSessionId&&(d.resume=this.claudeSessionId);for await(const p of Qs({prompt:t,options:d}))this._processMessage(p)}catch(u){u.name!=="AbortError"&&this.emit("agent:error",{message:u.message})}finally{this._busy=!1,this._abortController=null,this.emit("agent:busy",!1)}}_processMessage(t){const u=!!this.claudeSessionId;t.session_id&&!this.claudeSessionId&&(this.claudeSessionId=t.session_id),t.type==="system"&&t.subtype==="init"&&t.session_id&&(this.claudeSessionId=t.session_id),!u&&this.claudeSessionId&&this.emit("session-id",this.claudeSessionId);const d={...t,timestamp:Date.now()};if(JSON.stringify(d).length>10240&&(d._truncated=!0),this._history.push(d),this._history.length>500&&(this._history=this._history.slice(-500)),this.emit("agent:message",t),t.type==="rate_limit_event"&&t.rate_limit_info&&(this._usage.rateLimitInfo=t.rate_limit_info),t.type==="result"){if(this._usage.queryCount++,t.total_cost_usd&&(this._usage.totalCostUSD+=t.total_cost_usd),t.usage){this._usage.totalInputTokens+=t.usage.input_tokens||0,this._usage.totalOutputTokens+=t.usage.output_tokens||0,this._usage.totalCacheReadTokens+=t.usage.cache_read_input_tokens||0,this._usage.totalCacheCreationTokens+=t.usage.cache_creation_input_tokens||0;const h=(t.usage.input_tokens||0)+(t.usage.cache_read_input_tokens||0);h>0&&(this._usage.lastInputTokens=h)}if(t.modelUsage)for(const[h,x]of Object.entries(t.modelUsage))this._usage.modelUsage[h]||(this._usage.modelUsage[h]={inputTokens:0,outputTokens:0,costUSD:0}),this._usage.modelUsage[h].inputTokens+=x.inputTokens||0,this._usage.modelUsage[h].outputTokens+=x.outputTokens||0,this._usage.modelUsage[h].costUSD+=x.costUSD||0}}_isPathAllowed(t){if(!this.userDir||!t)return!0;const u=(0,external_path_.resolve)((0,external_path_.normalize)(this.userDir)),d=(0,external_path_.resolve)((0,external_path_.normalize)(this.cwd),(0,external_path_.normalize)(t));return d===u||d.startsWith(u+external_path_.sep)}_extractPaths(t,u){if(!u)return[];const d=[];return u.file_path&&d.push(u.file_path),u.path&&d.push(u.path),d}_isBashCommandSafe(t){if(!this.userDir||!t)return!0;const u=(0,external_path_.resolve)((0,external_path_.normalize)(this.userDir)),d=process.platform==="win32"?/[A-Za-z]:[\\\/]/g:/(?:^|[\s;|&`"'(])\/(?!dev\/null)/g;if(!t.match(d))return!0;const h=process.platform==="win32"?t.match(/[A-Za-z]:[\\\/][^\s;|&`"')}\]>]*/g)||[]:t.match(/\/[^\s;|&`"')}\]>]*/g)||[];for(const x of h){const $=(0,external_path_.resolve)((0,external_path_.normalize)(x));if($!==u&&!$.startsWith(u+external_path_.sep))return!1}return!0}async _handlePermission(t,u,d){for(const h of this._extractPaths(t,u))if(!this._isPathAllowed(h))return this.emit("agent:message",{type:"system",content:`[\u8DEF\u5F84\u9650\u5236] ${t} \u76EE\u6807 ${h} \u4E0D\u5728\u5F53\u524D\u9879\u76EE\u76EE\u5F55\u5185\uFF0C\u5DF2\u8DF3\u8FC7`}),{behavior:"deny",message:"\u8BE5\u8DEF\u5F84\u4E0D\u5728\u5F53\u524D\u9879\u76EE\u76EE\u5F55\u5185\uFF0C\u8BF7\u6539\u7528\u9879\u76EE\u76EE\u5F55\u4E0B\u7684\u8DEF\u5F84\u3002\u4F60\u4ECD\u7136\u53EF\u4EE5\u6B63\u5E38\u8BFB\u5199\u9879\u76EE\u76EE\u5F55\u5185\u7684\u4EFB\u4F55\u6587\u4EF6\u3002"};if(t==="Bash"&&u?.command&&!this._isBashCommandSafe(u.command))return this.emit("agent:message",{type:"system",content:"[\u8DEF\u5F84\u9650\u5236] Bash \u547D\u4EE4\u5F15\u7528\u4E86\u9879\u76EE\u5916\u8DEF\u5F84\uFF0C\u5DF2\u8DF3\u8FC7"}),{behavior:"deny",message:"\u547D\u4EE4\u4E2D\u5305\u542B\u9879\u76EE\u76EE\u5F55\u5916\u7684\u8DEF\u5F84\uFF0C\u8BF7\u53EA\u4F7F\u7528\u9879\u76EE\u76EE\u5F55\u5185\u7684\u8DEF\u5F84\u3002\u4F60\u4ECD\u7136\u53EF\u4EE5\u6B63\u5E38\u6267\u884C\u5176\u4ED6\u547D\u4EE4\u3002"};if(this._autoApproveTools.has(t)||this._autoApproveTools.has("*"))return{behavior:"allow"};const p=(0,external_crypto_.randomUUID)();return this.emit("agent:message",{type:"control_request",request_id:p,request:{tool_name:t,input:u}}),new Promise((h=>{this._pendingPermissions.set(p,h)}))}respondPermission(t,u,d,p){const h=this._pendingPermissions.get(t);h&&(this._pendingPermissions.delete(t),u?(p&&d?this._autoApproveTools.add(d):p&&!d&&this._autoApproveTools.add("*"),h({behavior:"allow"})):h({behavior:"deny",message:"\u7528\u6237\u62D2\u7EDD"}))}setPermissionMode(t){this.permissionMode=t}interrupt(){this._abortController&&this._abortController.abort();for(const[,t]of this._pendingPermissions)t({behavior:"deny",message:"\u5DF2\u4E2D\u65AD"});this._pendingPermissions.clear(),this.emit("agent:message",{type:"system",subtype:"interrupted",message:"\u67E5\u8BE2\u5DF2\u4E2D\u65AD"})}kill(){this.alive=!1,this.interrupt()}_loadResumedHistory(){try{const t=(0,external_path_.join)((0,external_os_.homedir)(),".claude","projects");if(!(0,external_fs_.existsSync)(t))return;for(const u of(0,external_fs_.readdirSync)(t,{withFileTypes:!0})){if(!u.isDirectory())continue;const d=(0,external_path_.join)(t,u.name,this.claudeSessionId+".jsonl");if(!(0,external_fs_.existsSync)(d))continue;const h=(0,external_fs_.readFileSync)(d,"utf8").split(`
465
465
  `).filter(Boolean).slice(-20);for(const x of h)try{const $=JSON.parse(x);if($.type==="human"&&$.message?.content){const b=typeof $.message.content=="string"?$.message.content:$.message.content.find((w=>w.type==="text"))?.text||"";b&&this._history.push({type:"user",content:b,timestamp:$.timestamp})}else $.type==="assistant"&&$.message?.content?this._history.push({type:"assistant",message:$.message,timestamp:$.timestamp}):$.type==="result"&&this._history.push({type:"result",total_cost_usd:$.costUSD||$.total_cost_usd,timestamp:$.timestamp})}catch{}return}}catch(t){console.warn("[agent] \u52A0\u8F7D\u6062\u590D\u4F1A\u8BDD\u5386\u53F2\u5931\u8D25:",t.message)}}get isBusy(){return this._busy}addViewer(t,u){this._viewers.add(t),u&&this._viewerNames.set(t,u)}removeViewer(t){this._viewers.delete(t),this._viewerNames.delete(t)}get viewerCount(){return new Set(this._viewerNames.values()).size||this._viewers.size}takeControl(t,u){this.controlHolder=t,this.controlHolderName=u||null,this.lastInputTime=Date.now()}releaseControl(){this.controlHolder=null,this.controlHolderName=null,this.lastInputTime=null}isController(t){return this.controlHolder===t}toJSON(){return{id:this.id,title:this.title,cwd:this.cwd,createdAt:this.createdAt,mode:"agent",alive:this.alive,viewers:this.viewerCount,controlHolder:this.controlHolder,controlHolderName:this.controlHolderName,permissionMode:this.permissionMode,owner:this.owner,claudeSessionId:this.claudeSessionId,busy:this._busy,usage:this._usage}}}let _claudeSessionsCache=null,_claudeSessionsCacheTime=0;const CLAUDE_SESSIONS_CACHE_TTL=3e4;function listLocalClaudeSessions(r){const t=Date.now();if(_claudeSessionsCache&&t-_claudeSessionsCacheTime<CLAUDE_SESSIONS_CACHE_TTL){if(!r)return _claudeSessionsCache;const h=(0,external_path_.resolve)((0,external_path_.normalize)(r)).replace(/[\\/]+$/,"");return _claudeSessionsCache.filter((x=>(0,external_path_.resolve)((0,external_path_.normalize)(x.projectPath)).replace(/[\\/]+$/,"").startsWith(h)))}const u=[],d=r?(0,external_path_.resolve)((0,external_path_.normalize)(r)).replace(/[\\/]+$/,""):null;try{const h=(0,external_path_.join)((0,external_os_.homedir)(),".claude","projects");if(!(0,external_fs_.existsSync)(h))return u;for(const x of(0,external_fs_.readdirSync)(h,{withFileTypes:!0})){if(!x.isDirectory())continue;const $=(0,external_path_.join)(h,x.name);try{for(const b of(0,external_fs_.readdirSync)($)){if(!b.endsWith(".jsonl"))continue;const w=b.replace(".jsonl",""),j=(0,external_path_.join)($,b);try{const N=(0,external_fs_.readFileSync)(j,"utf8").split(`
466
466
  `).filter(Boolean);let I=null,U=null,z=0,O="";for(const L of N)try{const W=JSON.parse(L);if(I||(I=W),U=W,z++,!O&&W.type==="human"&&W.message?.content){const H=W.message.content;if(typeof H=="string")O=H.slice(0,120);else if(Array.isArray(H)){const V=H.find((J=>J.type==="text"));V&&(O=V.text?.slice(0,120)||"")}}}catch{}let B=x.name;if(process.platform==="win32"&&/^[A-Za-z]--/.test(B)?B=B[0]+":\\"+B.slice(3).replace(/-/g,"\\"):B.startsWith("-")&&(B=B.replace(/-/g,"/")),d&&!(0,external_path_.resolve)((0,external_path_.normalize)(B)).replace(/[\\/]+$/,"").startsWith(d))continue;u.push({sessionId:w,projectDir:x.name,projectPath:B,messageCount:z,summary:O,createdAt:I?.timestamp||null,updatedAt:U?.timestamp||null})}catch{}}}catch{}}}catch{}u.sort(((h,x)=>new Date(x.updatedAt||0).getTime()-new Date(h.updatedAt||0).getTime()));const p=u.slice(0,50);return _claudeSessionsCache=p,_claudeSessionsCacheTime=Date.now(),p.slice(0,20)}const CONFIG_DIR=(0,external_path_.join)((0,external_os_.homedir)(),".zihi"),SESSIONS_FILE=(0,external_path_.join)(CONFIG_DIR,"sessions.json");function loadSavedConfigs(){try{return JSON.parse((0,external_fs_.readFileSync)(SESSIONS_FILE,"utf8"))}catch{return[]}}function writeSavedConfigs(r){try{(0,external_fs_.mkdirSync)(CONFIG_DIR,{recursive:!0});const t=SESSIONS_FILE+".tmp";(0,external_fs_.writeFileSync)(t,JSON.stringify(r,null,2),{mode:384}),(0,external_fs_.renameSync)(t,SESSIONS_FILE)}catch(t){console.error("[sessions] \u6301\u4E45\u5316\u5199\u5165\u5931\u8D25:",t.message)}}class SessionManager{constructor(){this._agentSessions=new Map;for(const t of loadSavedConfigs())try{if(t.claudeSessionId){const u=(0,external_crypto_.randomUUID)(),d=new AgentSession(u,{...t,resumeSessionId:t.claudeSessionId});d.on("session-id",(()=>this._persist())),this._agentSessions.set(u,d),console.log(`[\u4F1A\u8BDD] \u6062\u590D Agent "${t.title}" (claude: ${t.claudeSessionId.slice(0,8)}...)`)}}catch(u){console.warn(`[\u4F1A\u8BDD] \u6062\u590D "${t.title}" \u5931\u8D25:`,u.message)}}createAgent(t={}){const u=(0,external_crypto_.randomUUID)(),d=new AgentSession(u,t);return this._agentSessions.set(u,d),d.on("session-id",(()=>this._persist())),this._persist(),d}get(t){return this._agentSessions.get(t)}list(t,u=!1){let d=[...this._agentSessions.values()].map((p=>p.toJSON()));return t&&!u&&(d=d.filter((p=>!p.owner||p.owner===t))),d}listSessions(){return[...this._agentSessions.values()]}kill(t){const u=this._agentSessions.get(t);u&&(u.kill(),this._agentSessions.delete(t),this._persist())}persist(){this._persist()}_persist(){const t=[...this._agentSessions.values()].filter((u=>u.alive)).map((u=>({mode:"agent",title:u.title,cwd:u.cwd,permissionMode:u.permissionMode||void 0,owner:u.owner||void 0,userDir:u.userDir||void 0,claudeSessionId:u.claudeSessionId||void 0})));writeSavedConfigs(t)}}const roles_CONFIG_DIR=(0,external_path_.join)((0,external_os_.homedir)(),".zihi"),ROLES_FILE=(0,external_path_.join)(roles_CONFIG_DIR,"roles.json"),USERS_FILE=(0,external_path_.join)(roles_CONFIG_DIR,"users.json"),ROLE_LEVELS={admin:3,operator:2,viewer:1};let rolesConfig=null;function loadRoles(){try{if((0,external_fs_.existsSync)(ROLES_FILE))return rolesConfig=JSON.parse((0,external_fs_.readFileSync)(ROLES_FILE,"utf8")),rolesConfig}catch(r){console.warn("[\u89D2\u8272] \u52A0\u8F7D roles.json \u5931\u8D25:",r.message)}return rolesConfig=null,null}function lookupPassword(r){if(!rolesConfig?.passwords)return null;const t=rolesConfig.passwords[r];return t?{name:t.name||"\u7528\u6237",role:t.role||"viewer"}:null}function hasPermission(r,t){return(ROLE_LEVELS[r]||0)>=(ROLE_LEVELS[t]||0)}function isMultiUserMode(){return rolesConfig!==null&&rolesConfig.passwords&&Object.keys(rolesConfig.passwords).length>0}function getDefaultRole(){return rolesConfig?.defaultRole||"admin"}let usersConfig=null;function loadUsers(){try{if((0,external_fs_.existsSync)(USERS_FILE))return usersConfig=JSON.parse((0,external_fs_.readFileSync)(USERS_FILE,"utf8")),usersConfig}catch(r){console.warn("[\u7528\u6237] \u52A0\u8F7D users.json \u5931\u8D25:",r.message)}return usersConfig=null,null}function hasUsers(){return usersConfig!==null&&usersConfig.users&&Object.keys(usersConfig.users).length>0}function isExclusiveMode(){return hasUsers()&&usersConfig.exclusive===!0}function setExclusiveMode(r){usersConfig||(usersConfig={users:{}}),usersConfig.exclusive=!!r,_writeUsers()}function lookupUser(r){if(!usersConfig?.users)return null;const t=usersConfig.users[r];return t?{name:t.name||"\u7528\u6237",dir:t.dir}:null}function listUsers(){return usersConfig?.users?Object.entries(usersConfig.users).map((([r,t])=>({password:r.slice(0,2)+"*".repeat(r.length-2),name:t.name,dir:t.dir}))):[]}function addUser(r,t,u){usersConfig||(usersConfig={users:{}}),usersConfig.users||(usersConfig.users={}),usersConfig.users[r]={name:t,dir:u},_writeUsers()}function removeUser(r){return!usersConfig?.users||!usersConfig.users[r]?!1:(delete usersConfig.users[r],_writeUsers(),!0)}function _writeUsers(){(0,external_fs_.mkdirSync)(roles_CONFIG_DIR,{recursive:!0}),(0,external_fs_.writeFileSync)(USERS_FILE,JSON.stringify(usersConfig,null,2),{mode:384})}const server_dirname=(0,external_path_.dirname)((0,external_url_.fileURLToPath)(import.meta.url));let PORT=parseInt(process.env.PORT,10)||12345;const HOST=process.env.HOST||"0.0.0.0",PORT_EXPLICIT=!!process.env.PORT,DEFAULT_ROOT=(0,external_path_.resolve)((0,external_path_.normalize)(process.env.ZIHI_CWD||process.cwd()));function getEffectiveRoot(r){return r?(0,external_path_.resolve)((0,external_path_.normalize)(r)):DEFAULT_ROOT}const configDir=(0,external_path_.join)((0,external_os_.homedir)(),".zihi");(0,external_fs_.mkdirSync)(configDir,{recursive:!0});const pidFile=(0,external_path_.join)(configDir,"daemon.pid"),IS_DAEMON_CHILD=!!process.env.ZIHI_DAEMON;(function r(){if(!IS_DAEMON_CHILD){try{const t=parseInt((0,external_fs_.readFileSync)(pidFile,"utf8").trim(),10);if(t&&t!==process.pid){let u=!1;try{process.kill(t,0),u=!0}catch{}if(u){console.log(`[zihi] \u68C0\u6D4B\u5230\u5DF2\u8FD0\u884C\u7684\u5B9E\u4F8B (PID ${t})\uFF0C\u6B63\u5728\u505C\u6B62...`);try{process.platform==="win32"?(0,external_child_process_namespaceObject.execSync)(`taskkill /PID ${t} /F /T`,{stdio:"pipe",timeout:5e3}):process.kill(t,"SIGTERM")}catch(h){console.warn(`[zihi] \u505C\u6B62\u65E7\u8FDB\u7A0B\u5931\u8D25: ${h.message?.split(`
467
467
  `)[0]||h}`)}const d=Date.now()+5e3;for(;Date.now()<d;){try{process.kill(t,0)}catch{break}const h=Date.now()+200;for(;Date.now()<h;);}let p=!1;try{process.kill(t,0),p=!0}catch{}p&&(console.error(`[zihi] \u65E0\u6CD5\u505C\u6B62\u65E7\u8FDB\u7A0B (PID ${t})\uFF0C\u8BF7\u624B\u52A8\u6267\u884C\uFF1A`),console.error(" zihi stop"),console.error(` \u6216: ${process.platform==="win32"?`taskkill /PID ${t} /F`:`kill -9 ${t}`}`),process.exit(1))}}}catch{}IS_DAEMON_CHILD||(0,external_fs_.writeFileSync)(pidFile,String(process.pid))}})();function cleanupPid(){try{parseInt((0,external_fs_.readFileSync)(pidFile,"utf8").trim(),10)===process.pid&&(0,external_fs_.unlinkSync)(pidFile)}catch{}}function gracefulShutdown(){try{if(typeof manager<"u"){try{manager.persist()}catch{}for(const r of manager.listSessions())try{r.kill()}catch{}}}catch{}cleanupPid()}process.on("exit",cleanupPid),process.on("SIGTERM",(()=>{gracefulShutdown(),process.exit(0)})),process.on("SIGINT",(()=>{gracefulShutdown(),process.exit(0)})),process.on("uncaughtException",(r=>{console.error("[zihi] \u672A\u6355\u83B7\u5F02\u5E38:",r.message),gracefulShutdown(),process.exit(1)})),process.on("unhandledRejection",(r=>{console.error("[zihi] \u672A\u5904\u7406\u7684 Promise \u62D2\u7EDD:",r)}));function readOrCreate(r,t){try{if((0,external_fs_.existsSync)(r))return(0,external_fs_.readFileSync)(r,"utf8").trim()}catch{}const u=t();return(0,external_fs_.writeFileSync)(r,u,{mode:384}),u}const TOKEN=readOrCreate((0,external_path_.join)(configDir,"token"),(()=>(0,external_crypto_.randomBytes)(16).toString("hex")));let PASSWORD=readOrCreate((0,external_path_.join)(configDir,"password"),(()=>String(Math.floor(1e3+Math.random()*9e3))));loadRoles(),loadUsers();let activeUser=null;const userSessions=new Map;userSessions.set(TOKEN,{role:"admin",name:"\u7BA1\u7406\u5458",permanent:!0});const SESSION_MAX_AGE=10080*60*1e3;setInterval((()=>{const r=Date.now();for(const[t,u]of userSessions)u.permanent||(!u.lastUsed||r-u.lastUsed>SESSION_MAX_AGE)&&userSessions.delete(t)}),3600*1e3);function getTailscaleIP(){try{return(0,external_child_process_namespaceObject.execSync)("tailscale ip -4",{timeout:3e3,stdio:"pipe"}).toString().trim().split(`
package/dist/login.html CHANGED
@@ -138,7 +138,7 @@
138
138
  <button type="submit" id="btn">进入</button>
139
139
  </form>
140
140
 
141
- <div class="hint">密码见服务器启动日志<br>或编辑 ~/.zihi/password</div>
141
+ <div class="hint">密码见服务器启动日志</div>
142
142
  </div>
143
143
 
144
144
  <script>
package/dist/package.json CHANGED
@@ -1 +1 @@
1
- {"type":"module","version":"1.1.7"}
1
+ {"type":"module","version":"1.1.9"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@wendongfly/zihi",
3
- "version": "1.1.8",
3
+ "version": "1.1.10",
4
4
  "description": "AI Agent terminal sharing with interactive permission approval via Claude Agent SDK",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",