hud-mcp 2.0.1 → 2.0.2
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/main.js +1 -1
- package/package.json +1 -1
package/dist/main.js
CHANGED
|
@@ -164,7 +164,7 @@ Set the \`cycles\` parameter to \`"ref"\` to resolve cyclical schemas with defs.
|
|
|
164
164
|
`:`[${n[c]}\r
|
|
165
165
|
]`;continue}i+=n[c],n[c]==="\\"?o=!0:a&&n[c]==="]"?a=!1:!a&&n[c]==="["&&(a=!0)}try{new RegExp(i)}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`),e.source}return i}function xy(e,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"&&e.keyType?._def.typeName===H.ZodEnum)return{type:"object",required:e.keyType._def.values,properties:e.keyType._def.values.reduce((n,i)=>({...n,[i]:Ue(e.valueType._def,{...t,currentPath:[...t.currentPath,"properties",i]})??lr(t)}),{}),additionalProperties:t.rejectedAdditionalProperties};let r={type:"object",additionalProperties:Ue(e.valueType._def,{...t,currentPath:[...t.currentPath,"additionalProperties"]})??t.allowedAdditionalProperties};if(t.target==="openApi3")return r;if(e.keyType?._def.typeName===H.ZodString&&e.keyType._def.checks?.length){let{type:n,...i}=by(e.keyType._def,t);return{...r,propertyNames:i}}else{if(e.keyType?._def.typeName===H.ZodEnum)return{...r,propertyNames:{enum:e.keyType._def.values}};if(e.keyType?._def.typeName===H.ZodBranded&&e.keyType._def.type._def.typeName===H.ZodString&&e.keyType._def.type._def.checks?.length){let{type:n,...i}=By(e.keyType._def,t);return{...r,propertyNames:i}}}return r}function UO(e,t){if(t.mapStrategy==="record")return xy(e,t);let r=Ue(e.keyType._def,{...t,currentPath:[...t.currentPath,"items","items","0"]})||lr(t),n=Ue(e.valueType._def,{...t,currentPath:[...t.currentPath,"items","items","1"]})||lr(t);return{type:"array",maxItems:125,items:{type:"array",items:[r,n],minItems:2,maxItems:2}}}function FO(e){let t=e.values,n=Object.keys(e.values).filter(o=>typeof t[t[o]]!="number").map(o=>t[o]),i=Array.from(new Set(n.map(o=>typeof o)));return{type:i.length===1?i[0]==="string"?"string":"number":["string","number"],enum:n}}function LO(e){return e.target==="openAi"?void 0:{not:lr({...e,currentPath:[...e.currentPath,"not"]})}}function MO(e){return e.target==="openApi3"?{enum:["null"],nullable:!0}:{type:"null"}}var qp={ZodString:"string",ZodNumber:"number",ZodBigInt:"integer",ZodBoolean:"boolean",ZodNull:"null"};function PO(e,t){if(t.target==="openApi3")return $O(e,t);let r=e.options instanceof Map?Array.from(e.options.values()):e.options;if(r.every(n=>n._def.typeName in qp&&(!n._def.checks||!n._def.checks.length))){let n=r.reduce((i,o)=>{let a=qp[o._def.typeName];return a&&!i.includes(a)?[...i,a]:i},[]);return{type:n.length>1?n:n[0]}}else if(r.every(n=>n._def.typeName==="ZodLiteral"&&!n.description)){let n=r.reduce((i,o)=>{let a=typeof o._def.value;switch(a){case"string":case"number":case"boolean":return[...i,a];case"bigint":return[...i,"integer"];case"object":if(o._def.value===null)return[...i,"null"];default:return i}},[]);if(n.length===r.length){let i=n.filter((o,a,s)=>s.indexOf(o)===a);return{type:i.length>1?i:i[0],enum:r.reduce((o,a)=>o.includes(a._def.value)?o:[...o,a._def.value],[])}}}else if(r.every(n=>n._def.typeName==="ZodEnum"))return{type:"string",enum:r.reduce((n,i)=>[...n,...i._def.values.filter(o=>!n.includes(o))],[])};return $O(e,t)}var $O=(e,t)=>{let r=(e.options instanceof Map?Array.from(e.options.values()):e.options).map((n,i)=>Ue(n._def,{...t,currentPath:[...t.currentPath,"anyOf",`${i}`]})).filter(n=>!!n&&(!t.strictUnions||typeof n=="object"&&Object.keys(n).length>0));return r.length?{anyOf:r}:void 0};function OO(e,t){if(["ZodString","ZodNumber","ZodBigInt","ZodBoolean","ZodNull"].includes(e.innerType._def.typeName)&&(!e.innerType._def.checks||!e.innerType._def.checks.length))return t.target==="openApi3"?{type:qp[e.innerType._def.typeName],nullable:!0}:{type:[qp[e.innerType._def.typeName],"null"]};if(t.target==="openApi3"){let n=Ue(e.innerType._def,{...t,currentPath:[...t.currentPath]});return n&&"$ref"in n?{allOf:[n],nullable:!0}:n&&{...n,nullable:!0}}let r=Ue(e.innerType._def,{...t,currentPath:[...t.currentPath,"anyOf","0"]});return r&&{anyOf:[r,{type:"null"}]}}function zO(e,t){let r={type:"number"};if(!e.checks)return r;for(let n of e.checks)switch(n.kind){case"int":r.type="integer",WS(r,"type",n.message,t);break;case"min":t.target==="jsonSchema7"?n.inclusive?ht(r,"minimum",n.value,n.message,t):ht(r,"exclusiveMinimum",n.value,n.message,t):(n.inclusive||(r.exclusiveMinimum=!0),ht(r,"minimum",n.value,n.message,t));break;case"max":t.target==="jsonSchema7"?n.inclusive?ht(r,"maximum",n.value,n.message,t):ht(r,"exclusiveMaximum",n.value,n.message,t):(n.inclusive||(r.exclusiveMaximum=!0),ht(r,"maximum",n.value,n.message,t));break;case"multipleOf":ht(r,"multipleOf",n.value,n.message,t);break}return r}function qO(e,t){let r=t.target==="openAi",n={type:"object",properties:{}},i=[],o=e.shape();for(let s in o){let c=o[s];if(c===void 0||c._def===void 0)continue;let u=Zue(c);u&&r&&(c._def.typeName==="ZodOptional"&&(c=c._def.innerType),c.isNullable()||(c=c.nullable()),u=!1);let l=Ue(c._def,{...t,currentPath:[...t.currentPath,"properties",s],propertyPath:[...t.currentPath,"properties",s]});l!==void 0&&(n.properties[s]=l,u||i.push(s))}i.length&&(n.required=i);let a=Jue(e,t);return a!==void 0&&(n.additionalProperties=a),n}function Jue(e,t){if(e.catchall._def.typeName!=="ZodNever")return Ue(e.catchall._def,{...t,currentPath:[...t.currentPath,"additionalProperties"]});switch(e.unknownKeys){case"passthrough":return t.allowedAdditionalProperties;case"strict":return t.rejectedAdditionalProperties;case"strip":return t.removeAdditionalStrategy==="strict"?t.allowedAdditionalProperties:t.rejectedAdditionalProperties}}function Zue(e){try{return e.isOptional()}catch{return!0}}var VO=(e,t)=>{if(t.currentPath.toString()===t.propertyPath?.toString())return Ue(e.innerType._def,t);let r=Ue(e.innerType._def,{...t,currentPath:[...t.currentPath,"anyOf","1"]});return r?{anyOf:[{not:lr(t)},r]}:lr(t)};var jO=(e,t)=>{if(t.pipeStrategy==="input")return Ue(e.in._def,t);if(t.pipeStrategy==="output")return Ue(e.out._def,t);let r=Ue(e.in._def,{...t,currentPath:[...t.currentPath,"allOf","0"]}),n=Ue(e.out._def,{...t,currentPath:[...t.currentPath,"allOf",r?"1":"0"]});return{allOf:[r,n].filter(i=>i!==void 0)}};function GO(e,t){return Ue(e.type._def,t)}function HO(e,t){let n={type:"array",uniqueItems:!0,items:Ue(e.valueType._def,{...t,currentPath:[...t.currentPath,"items"]})};return e.minSize&&ht(n,"minItems",e.minSize.value,e.minSize.message,t),e.maxSize&&ht(n,"maxItems",e.maxSize.value,e.maxSize.message,t),n}function YO(e,t){return e.rest?{type:"array",minItems:e.items.length,items:e.items.map((r,n)=>Ue(r._def,{...t,currentPath:[...t.currentPath,"items",`${n}`]})).reduce((r,n)=>n===void 0?r:[...r,n],[]),additionalItems:Ue(e.rest._def,{...t,currentPath:[...t.currentPath,"additionalItems"]})}:{type:"array",minItems:e.items.length,maxItems:e.items.length,items:e.items.map((r,n)=>Ue(r._def,{...t,currentPath:[...t.currentPath,"items",`${n}`]})).reduce((r,n)=>n===void 0?r:[...r,n],[])}}function JO(e){return{not:lr(e)}}function ZO(e){return lr(e)}var WO=(e,t)=>Ue(e.innerType._def,t);var KO=(e,t,r)=>{switch(t){case H.ZodString:return by(e,r);case H.ZodNumber:return zO(e,r);case H.ZodObject:return qO(e,r);case H.ZodBigInt:return QO(e,r);case H.ZodBoolean:return wO();case H.ZodDate:return KS(e,r);case H.ZodUndefined:return JO(r);case H.ZodNull:return MO(r);case H.ZodArray:return xO(e,r);case H.ZodUnion:case H.ZodDiscriminatedUnion:return PO(e,r);case H.ZodIntersection:return RO(e,r);case H.ZodTuple:return YO(e,r);case H.ZodRecord:return xy(e,r);case H.ZodLiteral:return DO(e,r);case H.ZodEnum:return TO(e);case H.ZodNativeEnum:return FO(e);case H.ZodNullable:return OO(e,r);case H.ZodOptional:return VO(e,r);case H.ZodMap:return UO(e,r);case H.ZodSet:return HO(e,r);case H.ZodLazy:return()=>e.getter()._def;case H.ZodPromise:return GO(e,r);case H.ZodNaN:case H.ZodNever:return LO(r);case H.ZodEffects:return kO(e,r);case H.ZodAny:return lr(r);case H.ZodUnknown:return ZO(r);case H.ZodDefault:return _O(e,r);case H.ZodBranded:return By(e,r);case H.ZodReadonly:return WO(e,r);case H.ZodCatch:return SO(e,r);case H.ZodPipeline:return jO(e,r);case H.ZodFunction:case H.ZodVoid:case H.ZodSymbol:return;default:return(n=>{})(t)}};function Ue(e,t,r=!1){let n=t.seen.get(e);if(t.override){let s=t.override?.(e,t,n,r);if(s!==IO)return s}if(n&&!r){let s=Wue(n,t);if(s!==void 0)return s}let i={def:e,path:t.currentPath,jsonSchema:void 0};t.seen.set(e,i);let o=KO(e,e.typeName,t),a=typeof o=="function"?Ue(o(),t):o;if(a&&Kue(e,t,a),t.postProcess){let s=t.postProcess(a,e,t);return i.jsonSchema=a,s}return i.jsonSchema=a,a}var Wue=(e,t)=>{switch(t.$refStrategy){case"root":return{$ref:e.path.join("/")};case"relative":return{$ref:Iy(t.currentPath,e.path)};case"none":case"seen":return e.path.length<t.currentPath.length&&e.path.every((r,n)=>t.currentPath[n]===r)?(console.warn(`Recursive reference detected at ${t.currentPath.join("/")}! Defaulting to any`),lr(t)):t.$refStrategy==="seen"?lr(t):void 0}},Kue=(e,t,r)=>(e.description&&(r.description=e.description,t.markdownDescription&&(r.markdownDescription=e.description)),r);var t_=(e,t)=>{let r=bO(t),n=typeof t=="object"&&t.definitions?Object.entries(t.definitions).reduce((c,[u,l])=>({...c,[u]:Ue(l._def,{...r,currentPath:[...r.basePath,r.definitionPath,u]},!0)??lr(r)}),{}):void 0,i=typeof t=="string"?t:t?.nameStrategy==="title"?void 0:t?.name,o=Ue(e._def,i===void 0?r:{...r,currentPath:[...r.basePath,r.definitionPath,i]},!1)??lr(r),a=typeof t=="object"&&t.name!==void 0&&t.nameStrategy==="title"?t.name:void 0;a!==void 0&&(o.title=a),r.flags.hasReferencedOpenAiAnyType&&(n||(n={}),n[r.openAiAnyTypeName]||(n[r.openAiAnyTypeName]={type:["string","number","integer","boolean","array","null"],items:{$ref:r.$refStrategy==="relative"?"1":[...r.basePath,r.definitionPath,r.openAiAnyTypeName].join("/")}}));let s=i===void 0?n?{...o,[r.definitionPath]:n}:o:{$ref:[...r.$refStrategy==="relative"?[]:r.basePath,r.definitionPath,i].join("/"),[r.definitionPath]:{...n,[i]:o}};return r.target==="jsonSchema7"?s.$schema="http://json-schema.org/draft-07/schema#":(r.target==="jsonSchema2019-09"||r.target==="openAi")&&(s.$schema="https://json-schema.org/draft/2019-09/schema#"),r.target==="openAi"&&("anyOf"in s||"oneOf"in s||"allOf"in s||"type"in s&&Array.isArray(s.type))&&console.warn("Warning: OpenAI may not support schemas with unions as roots! Try wrapping it in an object property."),s};function Xue(e){return!e||e==="jsonSchema7"||e==="draft-7"?"draft-7":e==="jsonSchema2019-09"||e==="draft-2020-12"?"draft-2020-12":"draft-7"}function r_(e,t){return Fi(e)?wp(e,{target:Xue(t?.target),io:t?.pipeStrategy??"input"}):t_(e,{strictUnions:t?.strictUnions??!0,pipeStrategy:t?.pipeStrategy??"input"})}function n_(e){let r=Ds(e)?.method;if(!r)throw new Error("Schema is missing a method literal");let n=M0(r);if(typeof n!="string")throw new Error("Schema method literal must be a string");return n}function i_(e,t){let r=Rs(e,t);if(!r.success)throw r.error;return r.data}var ele=6e4,Qy=class{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(iy,r=>{this._oncancel(r)}),this.setNotificationHandler(ay,r=>{this._onprogress(r)}),this.setRequestHandler(oy,r=>({})),this._taskStore=t?.taskStore,this._taskMessageQueue=t?.taskMessageQueue,this._taskStore&&(this.setRequestHandler(sy,async(r,n)=>{let i=await this._taskStore.getTask(r.params.taskId,n.sessionId);if(!i)throw new me(Ce.InvalidParams,"Failed to retrieve task: Task not found");return{...i}}),this.setRequestHandler(uy,async(r,n)=>{let i=async()=>{let o=r.params.taskId;if(this._taskMessageQueue){let s;for(;s=await this._taskMessageQueue.dequeue(o,n.sessionId);){if(s.type==="response"||s.type==="error"){let c=s.message,u=c.id,l=this._requestResolvers.get(u);if(l)if(this._requestResolvers.delete(u),s.type==="response")l(c);else{let A=c,d=new me(A.error.code,A.error.message,A.error.data);l(d)}else{let A=s.type==="response"?"Response":"Error";this._onerror(new Error(`${A} handler missing for request ${u}`))}continue}await this._transport?.send(s.message,{relatedRequestId:n.requestId})}}let a=await this._taskStore.getTask(o,n.sessionId);if(!a)throw new me(Ce.InvalidParams,`Task not found: ${o}`);if(!Us(a.status))return await this._waitForTaskUpdate(o,n.signal),await i();if(Us(a.status)){let s=await this._taskStore.getTaskResult(o,n.sessionId);return this._clearTaskQueue(o),{...s,_meta:{...s._meta,[Ns]:{taskId:o}}}}return await i()};return await i()}),this.setRequestHandler(ly,async(r,n)=>{try{let{tasks:i,nextCursor:o}=await this._taskStore.listTasks(r.params?.cursor,n.sessionId);return{tasks:i,nextCursor:o,_meta:{}}}catch(i){throw new me(Ce.InvalidParams,`Failed to list tasks: ${i instanceof Error?i.message:String(i)}`)}}),this.setRequestHandler(dy,async(r,n)=>{try{let i=await this._taskStore.getTask(r.params.taskId,n.sessionId);if(!i)throw new me(Ce.InvalidParams,`Task not found: ${r.params.taskId}`);if(Us(i.status))throw new me(Ce.InvalidParams,`Cannot cancel task in terminal status: ${i.status}`);await this._taskStore.updateTaskStatus(r.params.taskId,"cancelled","Client cancelled task execution.",n.sessionId),this._clearTaskQueue(r.params.taskId);let o=await this._taskStore.getTask(r.params.taskId,n.sessionId);if(!o)throw new me(Ce.InvalidParams,`Task not found after cancellation: ${r.params.taskId}`);return{_meta:{},...o}}catch(i){throw i instanceof me?i:new me(Ce.InvalidRequest,`Failed to cancel task: ${i instanceof Error?i.message:String(i)}`)}}))}async _oncancel(t){if(!t.params.requestId)return;this._requestHandlerAbortControllers.get(t.params.requestId)?.abort(t.params.reason)}_setupTimeout(t,r,n,i,o=!1){this._timeoutInfo.set(t,{timeoutId:setTimeout(i,r),startTime:Date.now(),timeout:r,maxTotalTimeout:n,resetTimeoutOnProgress:o,onTimeout:i})}_resetTimeout(t){let r=this._timeoutInfo.get(t);if(!r)return!1;let n=Date.now()-r.startTime;if(r.maxTotalTimeout&&n>=r.maxTotalTimeout)throw this._timeoutInfo.delete(t),me.fromError(Ce.RequestTimeout,"Maximum total timeout exceeded",{maxTotalTimeout:r.maxTotalTimeout,totalElapsed:n});return clearTimeout(r.timeoutId),r.timeoutId=setTimeout(r.onTimeout,r.timeout),!0}_cleanupTimeout(t){let r=this._timeoutInfo.get(t);r&&(clearTimeout(r.timeoutId),this._timeoutInfo.delete(t))}async connect(t){this._transport=t;let r=this.transport?.onclose;this._transport.onclose=()=>{r?.(),this._onclose()};let n=this.transport?.onerror;this._transport.onerror=o=>{n?.(o),this._onerror(o)};let i=this._transport?.onmessage;this._transport.onmessage=(o,a)=>{i?.(o,a),Up(o)||lO(o)?this._onresponse(o):FS(o)?this._onrequest(o,a):uO(o)?this._onnotification(o):this._onerror(new Error(`Unknown message type: ${JSON.stringify(o)}`))},await this._transport.start()}_onclose(){let t=this._responseHandlers;this._responseHandlers=new Map,this._progressHandlers.clear(),this._taskProgressTokens.clear(),this._pendingDebouncedNotifications.clear();let r=me.fromError(Ce.ConnectionClosed,"Connection closed");this._transport=void 0,this.onclose?.();for(let n of t.values())n(r)}_onerror(t){this.onerror?.(t)}_onnotification(t){let r=this._notificationHandlers.get(t.method)??this.fallbackNotificationHandler;r!==void 0&&Promise.resolve().then(()=>r(t)).catch(n=>this._onerror(new Error(`Uncaught error in notification handler: ${n}`)))}_onrequest(t,r){let n=this._requestHandlers.get(t.method)??this.fallbackRequestHandler,i=this._transport,o=t.params?._meta?.[Ns]?.taskId;if(n===void 0){let l={jsonrpc:"2.0",id:t.id,error:{code:Ce.MethodNotFound,message:"Method not found"}};o&&this._taskMessageQueue?this._enqueueTaskMessage(o,{type:"error",message:l,timestamp:Date.now()},i?.sessionId).catch(A=>this._onerror(new Error(`Failed to enqueue error response: ${A}`))):i?.send(l).catch(A=>this._onerror(new Error(`Failed to send an error response: ${A}`)));return}let a=new AbortController;this._requestHandlerAbortControllers.set(t.id,a);let s=aO(t.params)?t.params.task:void 0,c=this._taskStore?this.requestTaskStore(t,i?.sessionId):void 0,u={signal:a.signal,sessionId:i?.sessionId,_meta:t.params?._meta,sendNotification:async l=>{let A={relatedRequestId:t.id};o&&(A.relatedTask={taskId:o}),await this.notification(l,A)},sendRequest:async(l,A,d)=>{let p={...d,relatedRequestId:t.id};o&&!p.relatedTask&&(p.relatedTask={taskId:o});let f=p.relatedTask?.taskId??o;return f&&c&&await c.updateTaskStatus(f,"input_required"),await this.request(l,A,p)},authInfo:r?.authInfo,requestId:t.id,requestInfo:r?.requestInfo,taskId:o,taskStore:c,taskRequestedTtl:s?.ttl,closeSSEStream:r?.closeSSEStream,closeStandaloneSSEStream:r?.closeStandaloneSSEStream};Promise.resolve().then(()=>{s&&this.assertTaskHandlerCapability(t.method)}).then(()=>n(t,u)).then(async l=>{if(a.signal.aborted)return;let A={result:l,jsonrpc:"2.0",id:t.id};o&&this._taskMessageQueue?await this._enqueueTaskMessage(o,{type:"response",message:A,timestamp:Date.now()},i?.sessionId):await i?.send(A)},async l=>{if(a.signal.aborted)return;let A={jsonrpc:"2.0",id:t.id,error:{code:Number.isSafeInteger(l.code)?l.code:Ce.InternalError,message:l.message??"Internal error",...l.data!==void 0&&{data:l.data}}};o&&this._taskMessageQueue?await this._enqueueTaskMessage(o,{type:"error",message:A,timestamp:Date.now()},i?.sessionId):await i?.send(A)}).catch(l=>this._onerror(new Error(`Failed to send response: ${l}`))).finally(()=>{this._requestHandlerAbortControllers.delete(t.id)})}_onprogress(t){let{progressToken:r,...n}=t.params,i=Number(r),o=this._progressHandlers.get(i);if(!o){this._onerror(new Error(`Received a progress notification for an unknown token: ${JSON.stringify(t)}`));return}let a=this._responseHandlers.get(i),s=this._timeoutInfo.get(i);if(s&&a&&s.resetTimeoutOnProgress)try{this._resetTimeout(i)}catch(c){this._responseHandlers.delete(i),this._progressHandlers.delete(i),this._cleanupTimeout(i),a(c);return}o(n)}_onresponse(t){let r=Number(t.id),n=this._requestResolvers.get(r);if(n){if(this._requestResolvers.delete(r),Up(t))n(t);else{let a=new me(t.error.code,t.error.message,t.error.data);n(a)}return}let i=this._responseHandlers.get(r);if(i===void 0){this._onerror(new Error(`Received a response for an unknown message ID: ${JSON.stringify(t)}`));return}this._responseHandlers.delete(r),this._cleanupTimeout(r);let o=!1;if(Up(t)&&t.result&&typeof t.result=="object"){let a=t.result;if(a.task&&typeof a.task=="object"){let s=a.task;typeof s.taskId=="string"&&(o=!0,this._taskProgressTokens.set(s.taskId,r))}}if(o||this._progressHandlers.delete(r),Up(t))i(t);else{let a=me.fromError(t.error.code,t.error.message,t.error.data);i(a)}}get transport(){return this._transport}async close(){await this._transport?.close()}async*requestStream(t,r,n){let{task:i}=n??{};if(!i){try{yield{type:"result",result:await this.request(t,r,n)}}catch(a){yield{type:"error",error:a instanceof me?a:new me(Ce.InternalError,String(a))}}return}let o;try{let a=await this.request(t,lA,n);if(a.task)o=a.task.taskId,yield{type:"taskCreated",task:a.task};else throw new me(Ce.InternalError,"Task creation did not return a task");for(;;){let s=await this.getTask({taskId:o},n);if(yield{type:"taskStatus",task:s},Us(s.status)){s.status==="completed"?yield{type:"result",result:await this.getTaskResult({taskId:o},r,n)}:s.status==="failed"?yield{type:"error",error:new me(Ce.InternalError,`Task ${o} failed`)}:s.status==="cancelled"&&(yield{type:"error",error:new me(Ce.InternalError,`Task ${o} was cancelled`)});return}if(s.status==="input_required"){yield{type:"result",result:await this.getTaskResult({taskId:o},r,n)};return}let c=s.pollInterval??this._options?.defaultTaskPollInterval??1e3;await new Promise(u=>setTimeout(u,c)),n?.signal?.throwIfAborted()}}catch(a){yield{type:"error",error:a instanceof me?a:new me(Ce.InternalError,String(a))}}}request(t,r,n){let{relatedRequestId:i,resumptionToken:o,onresumptiontoken:a,task:s,relatedTask:c}=n??{};return new Promise((u,l)=>{let A=B=>{l(B)};if(!this._transport){A(new Error("Not connected"));return}if(this._options?.enforceStrictCapabilities===!0)try{this.assertCapabilityForMethod(t.method),s&&this.assertTaskCapability(t.method)}catch(B){A(B);return}n?.signal?.throwIfAborted();let d=this._requestMessageId++,p={...t,jsonrpc:"2.0",id:d};n?.onprogress&&(this._progressHandlers.set(d,n.onprogress),p.params={...t.params,_meta:{...t.params?._meta||{},progressToken:d}}),s&&(p.params={...p.params,task:s}),c&&(p.params={...p.params,_meta:{...p.params?._meta||{},[Ns]:c}});let f=B=>{this._responseHandlers.delete(d),this._progressHandlers.delete(d),this._cleanupTimeout(d),this._transport?.send({jsonrpc:"2.0",method:"notifications/cancelled",params:{requestId:d,reason:String(B)}},{relatedRequestId:i,resumptionToken:o,onresumptiontoken:a}).catch(x=>this._onerror(new Error(`Failed to send cancellation: ${x}`)));let I=B instanceof me?B:new me(Ce.RequestTimeout,String(B));l(I)};this._responseHandlers.set(d,B=>{if(!n?.signal?.aborted){if(B instanceof Error)return l(B);try{let I=Rs(r,B.result);I.success?u(I.data):l(I.error)}catch(I){l(I)}}}),n?.signal?.addEventListener("abort",()=>{f(n?.signal?.reason)});let h=n?.timeout??ele,g=()=>f(me.fromError(Ce.RequestTimeout,"Request timed out",{timeout:h}));this._setupTimeout(d,h,n?.maxTotalTimeout,g,n?.resetTimeoutOnProgress??!1);let m=c?.taskId;if(m){let B=I=>{let x=this._responseHandlers.get(d);x?x(I):this._onerror(new Error(`Response handler missing for side-channeled request ${d}`))};this._requestResolvers.set(d,B),this._enqueueTaskMessage(m,{type:"request",message:p,timestamp:Date.now()}).catch(I=>{this._cleanupTimeout(d),l(I)})}else this._transport.send(p,{relatedRequestId:i,resumptionToken:o,onresumptiontoken:a}).catch(B=>{this._cleanupTimeout(d),l(B)})})}async getTask(t,r){return this.request({method:"tasks/get",params:t},cy,r)}async getTaskResult(t,r,n){return this.request({method:"tasks/result",params:t},r,n)}async listTasks(t,r){return this.request({method:"tasks/list",params:t},Ay,r)}async cancelTask(t,r){return this.request({method:"tasks/cancel",params:t},fO,r)}async notification(t,r){if(!this._transport)throw new Error("Not connected");this.assertNotificationCapability(t.method);let n=r?.relatedTask?.taskId;if(n){let s={...t,jsonrpc:"2.0",params:{...t.params,_meta:{...t.params?._meta||{},[Ns]:r.relatedTask}}};await this._enqueueTaskMessage(n,{type:"notification",message:s,timestamp:Date.now()});return}if((this._options?.debouncedNotificationMethods??[]).includes(t.method)&&!t.params&&!r?.relatedRequestId&&!r?.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 s={...t,jsonrpc:"2.0"};r?.relatedTask&&(s={...s,params:{...s.params,_meta:{...s.params?._meta||{},[Ns]:r.relatedTask}}}),this._transport?.send(s,r).catch(c=>this._onerror(c))});return}let a={...t,jsonrpc:"2.0"};r?.relatedTask&&(a={...a,params:{...a.params,_meta:{...a.params?._meta||{},[Ns]:r.relatedTask}}}),await this._transport.send(a,r)}setRequestHandler(t,r){let n=n_(t);this.assertRequestHandlerCapability(n),this._requestHandlers.set(n,(i,o)=>{let a=i_(t,i);return Promise.resolve(r(a,o))})}removeRequestHandler(t){this._requestHandlers.delete(t)}assertCanSetRequestHandler(t){if(this._requestHandlers.has(t))throw new Error(`A request handler for ${t} already exists, which would be overridden`)}setNotificationHandler(t,r){let n=n_(t);this._notificationHandlers.set(n,i=>{let o=i_(t,i);return Promise.resolve(r(o))})}removeNotificationHandler(t){this._notificationHandlers.delete(t)}_cleanupTaskProgressHandler(t){let r=this._taskProgressTokens.get(t);r!==void 0&&(this._progressHandlers.delete(r),this._taskProgressTokens.delete(t))}async _enqueueTaskMessage(t,r,n){if(!this._taskStore||!this._taskMessageQueue)throw new Error("Cannot enqueue task message: taskStore and taskMessageQueue are not configured");let i=this._options?.maxTaskQueueSize;await this._taskMessageQueue.enqueue(t,r,n,i)}async _clearTaskQueue(t,r){if(this._taskMessageQueue){let n=await this._taskMessageQueue.dequeueAll(t,r);for(let i of n)if(i.type==="request"&&FS(i.message)){let o=i.message.id,a=this._requestResolvers.get(o);a?(a(new me(Ce.InternalError,"Task cancelled or completed")),this._requestResolvers.delete(o)):this._onerror(new Error(`Resolver missing for request ${o} during task ${t} cleanup`))}}}async _waitForTaskUpdate(t,r){let n=this._options?.defaultTaskPollInterval??1e3;try{let i=await this._taskStore?.getTask(t);i?.pollInterval&&(n=i.pollInterval)}catch{}return new Promise((i,o)=>{if(r.aborted){o(new me(Ce.InvalidRequest,"Request cancelled"));return}let a=setTimeout(i,n);r.addEventListener("abort",()=>{clearTimeout(a),o(new me(Ce.InvalidRequest,"Request cancelled"))},{once:!0})})}requestTaskStore(t,r){let n=this._taskStore;if(!n)throw new Error("No task store configured");return{createTask:async i=>{if(!t)throw new Error("No request provided");return await n.createTask(i,t.id,{method:t.method,params:t.params},r)},getTask:async i=>{let o=await n.getTask(i,r);if(!o)throw new me(Ce.InvalidParams,"Failed to retrieve task: Task not found");return o},storeTaskResult:async(i,o,a)=>{await n.storeTaskResult(i,o,a,r);let s=await n.getTask(i,r);if(s){let c=Pp.parse({method:"notifications/tasks/status",params:s});await this.notification(c),Us(s.status)&&this._cleanupTaskProgressHandler(i)}},getTaskResult:i=>n.getTaskResult(i,r),updateTaskStatus:async(i,o,a)=>{let s=await n.getTask(i,r);if(!s)throw new me(Ce.InvalidParams,`Task "${i}" not found - it may have been cleaned up`);if(Us(s.status))throw new me(Ce.InvalidParams,`Cannot update task "${i}" from terminal status "${s.status}" to "${o}". Terminal states (completed, failed, cancelled) cannot transition to other states.`);await n.updateTaskStatus(i,o,a,r);let c=await n.getTask(i,r);if(c){let u=Pp.parse({method:"notifications/tasks/status",params:c});await this.notification(u),Us(c.status)&&this._cleanupTaskProgressHandler(i)}},listTasks:i=>n.listTasks(i,r)}}};function XO(e){return e!==null&&typeof e=="object"&&!Array.isArray(e)}function e4(e,t){let r={...e};for(let n in t){let i=n,o=t[i];if(o===void 0)continue;let a=r[i];XO(a)&&XO(o)?r[i]={...a,...o}:r[i]=o}return r}var Pq=Pt(qk(),1),Oq=Pt($q(),1);function jhe(){let e=new Pq.default({strict:!1,validateFormats:!0,validateSchema:!1,allErrors:!0});return(0,Oq.default)(e),e}var cE=class{constructor(t){this._ajv=t??jhe()}getValidator(t){let r="$id"in t&&typeof t.$id=="string"?this._ajv.getSchema(t.$id)??this._ajv.compile(t):this._ajv.compile(t);return n=>r(n)?{valid:!0,data:n,errorMessage:void 0}:{valid:!1,data:void 0,errorMessage:this._ajv.errorsText(r.errors)}}};var uE=class{constructor(t){this._server=t}requestStream(t,r,n){return this._server.requestStream(t,r,n)}async getTask(t,r){return this._server.getTask({taskId:t},r)}async getTaskResult(t,r,n){return this._server.getTaskResult({taskId:t},r,n)}async listTasks(t,r){return this._server.listTasks(t?{cursor:t}:void 0,r)}async cancelTask(t,r){return this._server.cancelTask({taskId:t},r)}};function zq(e,t,r){if(!e)throw new Error(`${r} does not support task creation (required for ${t})`);switch(t){case"tools/call":if(!e.tools?.call)throw new Error(`${r} does not support task creation for tools/call (required for ${t})`);break;default:break}}function qq(e,t,r){if(!e)throw new Error(`${r} does not support task creation (required for ${t})`);switch(t){case"sampling/createMessage":if(!e.sampling?.createMessage)throw new Error(`${r} does not support task creation for sampling/createMessage (required for ${t})`);break;case"elicitation/create":if(!e.elicitation?.create)throw new Error(`${r} does not support task creation for elicitation/create (required for ${t})`);break;default:break}}var lE=class extends Qy{constructor(t,r){super(r),this._serverInfo=t,this._loggingLevels=new Map,this.LOG_LEVEL_SEVERITY=new Map(zp.options.map((n,i)=>[n,i])),this.isMessageIgnored=(n,i)=>{let o=this._loggingLevels.get(i);return o?this.LOG_LEVEL_SEVERITY.get(n)<this.LOG_LEVEL_SEVERITY.get(o):!1},this._capabilities=r?.capabilities??{},this._instructions=r?.instructions,this._jsonSchemaValidator=r?.jsonSchemaValidator??new cE,this.setRequestHandler($S,n=>this._oninitialize(n)),this.setNotificationHandler(PS,()=>this.oninitialized?.()),this._capabilities.logging&&this.setRequestHandler(HS,async(n,i)=>{let o=i.sessionId||i.requestInfo?.headers["mcp-session-id"]||void 0,{level:a}=n.params,s=zp.safeParse(a);return s.success&&this._loggingLevels.set(o,s.data),{}})}get experimental(){return this._experimental||(this._experimental={tasks:new uE(this)}),this._experimental}registerCapabilities(t){if(this.transport)throw new Error("Cannot register capabilities after connecting to transport");this._capabilities=e4(this._capabilities,t)}setRequestHandler(t,r){let i=Ds(t)?.method;if(!i)throw new Error("Schema is missing a method literal");let o;if(Fi(i)){let s=i;o=s._zod?.def?.value??s.value}else{let s=i;o=s._def?.value??s.value}if(typeof o!="string")throw new Error("Schema method literal must be a string");if(o==="tools/call"){let s=async(c,u)=>{let l=Rs(dA,c);if(!l.success){let f=l.error instanceof Error?l.error.message:String(l.error);throw new me(Ce.InvalidParams,`Invalid tools/call request: ${f}`)}let{params:A}=l.data,d=await Promise.resolve(r(c,u));if(A.task){let f=Rs(lA,d);if(!f.success){let h=f.error instanceof Error?f.error.message:String(f.error);throw new me(Ce.InvalidParams,`Invalid task creation result: ${h}`)}return f.data}let p=Rs(Ey,d);if(!p.success){let f=p.error instanceof Error?p.error.message:String(p.error);throw new me(Ce.InvalidParams,`Invalid tools/call result: ${f}`)}return p.data};return super.setRequestHandler(t,s)}return super.setRequestHandler(t,r)}assertCapabilityForMethod(t){switch(t){case"sampling/createMessage":if(!this._clientCapabilities?.sampling)throw new Error(`Client does not support sampling (required for ${t})`);break;case"elicitation/create":if(!this._clientCapabilities?.elicitation)throw new Error(`Client does not support elicitation (required for ${t})`);break;case"roots/list":if(!this._clientCapabilities?.roots)throw new 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 new Error(`Server does not support logging (required for ${t})`);break;case"notifications/resources/updated":case"notifications/resources/list_changed":if(!this._capabilities.resources)throw new Error(`Server does not support notifying about resources (required for ${t})`);break;case"notifications/tools/list_changed":if(!this._capabilities.tools)throw new Error(`Server does not support notifying of tool list changes (required for ${t})`);break;case"notifications/prompts/list_changed":if(!this._capabilities.prompts)throw new Error(`Server does not support notifying of prompt list changes (required for ${t})`);break;case"notifications/elicitation/complete":if(!this._clientCapabilities?.elicitation?.url)throw new 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 new Error(`Server does not support completions (required for ${t})`);break;case"logging/setLevel":if(!this._capabilities.logging)throw new Error(`Server does not support logging (required for ${t})`);break;case"prompts/get":case"prompts/list":if(!this._capabilities.prompts)throw new 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 new Error(`Server does not support resources (required for ${t})`);break;case"tools/call":case"tools/list":if(!this._capabilities.tools)throw new 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 new Error(`Server does not support tasks capability (required for ${t})`);break;case"ping":case"initialize":break}}assertTaskCapability(t){qq(this._clientCapabilities?.tasks?.requests,t,"Client")}assertTaskHandlerCapability(t){this._capabilities&&zq(this._capabilities.tasks?.requests,t,"Server")}async _oninitialize(t){let r=t.params.protocolVersion;return this._clientCapabilities=t.params.capabilities,this._clientVersion=t.params.clientInfo,{protocolVersion:nO.includes(r)?r:NS,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"},ny)}async createMessage(t,r){if((t.tools||t.toolChoice)&&!this._clientCapabilities?.sampling?.tools)throw new Error("Client does not support sampling tools capability.");if(t.messages.length>0){let n=t.messages[t.messages.length-1],i=Array.isArray(n.content)?n.content:[n.content],o=i.some(u=>u.type==="tool_result"),a=t.messages.length>1?t.messages[t.messages.length-2]:void 0,s=a?Array.isArray(a.content)?a.content:[a.content]:[],c=s.some(u=>u.type==="tool_use");if(o){if(i.some(u=>u.type!=="tool_result"))throw new Error("The last message must contain only tool_result content if any is present");if(!c)throw new Error("tool_result blocks are not matching any tool_use from the previous message")}if(c){let u=new Set(s.filter(A=>A.type==="tool_use").map(A=>A.id)),l=new Set(i.filter(A=>A.type==="tool_result").map(A=>A.toolUseId));if(u.size!==l.size||![...u].every(A=>l.has(A)))throw new 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},JS,r):this.request({method:"sampling/createMessage",params:t},YS,r)}async elicitInput(t,r){switch(t.mode??"form"){case"url":{if(!this._clientCapabilities?.elicitation?.url)throw new Error("Client does not support url elicitation.");let i=t;return this.request({method:"elicitation/create",params:i},vy,r)}case"form":{if(!this._clientCapabilities?.elicitation?.form)throw new Error("Client does not support form elicitation.");let i=t.mode==="form"?t:{...t,mode:"form"},o=await this.request({method:"elicitation/create",params:i},vy,r);if(o.action==="accept"&&o.content&&i.requestedSchema)try{let s=this._jsonSchemaValidator.getValidator(i.requestedSchema)(o.content);if(!s.valid)throw new me(Ce.InvalidParams,`Elicitation response content does not match requested schema: ${s.errorMessage}`)}catch(a){throw a instanceof me?a:new me(Ce.InternalError,`Error validating elicitation response: ${a instanceof Error?a.message:String(a)}`)}return o}}}createElicitationCompletionNotifier(t,r){if(!this._clientCapabilities?.elicitation?.url)throw new Error("Client does not support URL elicitation (required for notifications/elicitation/complete)");return()=>this.notification({method:"notifications/elicitation/complete",params:{elicitationId:t}},r)}async listRoots(t,r){return this.request({method:"roots/list",params:t},ZS,r)}async sendLoggingMessage(t,r){if(this._capabilities.logging&&!this.isMessageIgnored(t.level,r))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 jq=Symbol.for("mcp.completable");function Wk(e){return!!e&&typeof e=="object"&&jq in e}function Gq(e){return e[jq]?.complete}var Vq;(function(e){e.Completable="McpCompletable"})(Vq||(Vq={}));var Ghe=/^[A-Za-z0-9._-]{1,128}$/;function Hhe(e){let t=[];if(e.length===0)return{isValid:!1,warnings:["Tool name cannot be empty"]};if(e.length>128)return{isValid:!1,warnings:[`Tool name exceeds maximum length of 128 characters (current: ${e.length})`]};if(e.includes(" ")&&t.push("Tool name contains spaces, which may cause parsing issues"),e.includes(",")&&t.push("Tool name contains commas, which may cause parsing issues"),(e.startsWith("-")||e.endsWith("-"))&&t.push("Tool name starts or ends with a dash, which may cause parsing issues in some contexts"),(e.startsWith(".")||e.endsWith("."))&&t.push("Tool name starts or ends with a dot, which may cause parsing issues in some contexts"),!Ghe.test(e)){let r=e.split("").filter(n=>!/[A-Za-z0-9._-]/.test(n)).filter((n,i,o)=>o.indexOf(n)===i);return t.push(`Tool name contains invalid characters: ${r.map(n=>`"${n}"`).join(", ")}`,"Allowed characters are: A-Z, a-z, 0-9, underscore (_), dash (-), and dot (.)"),{isValid:!1,warnings:t}}return{isValid:!0,warnings:t}}function Yhe(e,t){if(t.length>0){console.warn(`Tool name validation warning for "${e}":`);for(let r of t)console.warn(` - ${r}`);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 Kk(e){let t=Hhe(e);return Yhe(e,t.warnings),t.isValid}var AE=class{constructor(t){this._mcpServer=t}registerToolTask(t,r,n){let i={taskSupport:"required",...r.execution};if(i.taskSupport==="forbidden")throw new Error(`Cannot register task-based tool '${t}' with taskSupport 'forbidden'. Use registerTool() instead.`);return this._mcpServer._createRegisteredTool(t,r.title,r.description,r.inputSchema,r.outputSchema,r.annotations,i,r._meta,n)}};var dE=class{constructor(t,r){this._registeredResources={},this._registeredResourceTemplates={},this._registeredTools={},this._registeredPrompts={},this._toolHandlersInitialized=!1,this._completionHandlerInitialized=!1,this._resourceHandlersInitialized=!1,this._promptHandlersInitialized=!1,this.server=new lE(t,r)}get experimental(){return this._experimental||(this._experimental={tasks:new AE(this)}),this._experimental}async connect(t){return await this.server.connect(t)}async close(){await this.server.close()}setToolRequestHandlers(){this._toolHandlersInitialized||(this.server.assertCanSetRequestHandler(Vs(yy)),this.server.assertCanSetRequestHandler(Vs(dA)),this.server.registerCapabilities({tools:{listChanged:!0}}),this.server.setRequestHandler(yy,()=>({tools:Object.entries(this._registeredTools).filter(([,t])=>t.enabled).map(([t,r])=>{let n={name:t,title:r.title,description:r.description,inputSchema:(()=>{let i=sA(r.inputSchema);return i?r_(i,{strictUnions:!0,pipeStrategy:"input"}):Jhe})(),annotations:r.annotations,execution:r.execution,_meta:r._meta};if(r.outputSchema){let i=sA(r.outputSchema);i&&(n.outputSchema=r_(i,{strictUnions:!0,pipeStrategy:"output"}))}return n})})),this.server.setRequestHandler(dA,async(t,r)=>{try{let n=this._registeredTools[t.params.name];if(!n)throw new me(Ce.InvalidParams,`Tool ${t.params.name} not found`);if(!n.enabled)throw new me(Ce.InvalidParams,`Tool ${t.params.name} disabled`);let i=!!t.params.task,o=n.execution?.taskSupport,a="createTask"in n.handler;if((o==="required"||o==="optional")&&!a)throw new me(Ce.InternalError,`Tool ${t.params.name} has taskSupport '${o}' but was not registered with registerToolTask`);if(o==="required"&&!i)throw new me(Ce.MethodNotFound,`Tool ${t.params.name} requires task augmentation (taskSupport: 'required')`);if(o==="optional"&&!i&&a)return await this.handleAutomaticTaskPolling(n,t,r);let s=await this.validateToolInput(n,t.params.arguments,t.params.name),c=await this.executeToolHandler(n,s,r);return i||await this.validateToolOutput(n,c,t.params.name),c}catch(n){if(n instanceof me&&n.code===Ce.UrlElicitationRequired)throw n;return this.createToolError(n instanceof Error?n.message:String(n))}}),this._toolHandlersInitialized=!0)}createToolError(t){return{content:[{type:"text",text:t}],isError:!0}}async validateToolInput(t,r,n){if(!t.inputSchema)return;let o=sA(t.inputSchema)??t.inputSchema,a=await F0(o,r);if(!a.success){let s="error"in a?a.error:"Unknown error",c=L0(s);throw new me(Ce.InvalidParams,`Input validation error: Invalid arguments for tool ${n}: ${c}`)}return a.data}async validateToolOutput(t,r,n){if(!t.outputSchema||!("content"in r)||r.isError)return;if(!r.structuredContent)throw new me(Ce.InvalidParams,`Output validation error: Tool ${n} has an output schema but no structured content was provided`);let i=sA(t.outputSchema),o=await F0(i,r.structuredContent);if(!o.success){let a="error"in o?o.error:"Unknown error",s=L0(a);throw new me(Ce.InvalidParams,`Output validation error: Invalid structured content for tool ${n}: ${s}`)}}async executeToolHandler(t,r,n){let i=t.handler;if("createTask"in i){if(!n.taskStore)throw new Error("No task store provided.");let a={...n,taskStore:n.taskStore};if(t.inputSchema){let s=i;return await Promise.resolve(s.createTask(r,a))}else{let s=i;return await Promise.resolve(s.createTask(a))}}if(t.inputSchema){let a=i;return await Promise.resolve(a(r,n))}else{let a=i;return await Promise.resolve(a(n))}}async handleAutomaticTaskPolling(t,r,n){if(!n.taskStore)throw new Error("No task store provided for task-capable tool.");let i=await this.validateToolInput(t,r.params.arguments,r.params.name),o=t.handler,a={...n,taskStore:n.taskStore},s=i?await Promise.resolve(o.createTask(i,a)):await Promise.resolve(o.createTask(a)),c=s.task.taskId,u=s.task,l=u.pollInterval??5e3;for(;u.status!=="completed"&&u.status!=="failed"&&u.status!=="cancelled";){await new Promise(d=>setTimeout(d,l));let A=await n.taskStore.getTask(c);if(!A)throw new me(Ce.InternalError,`Task ${c} not found during polling`);u=A}return await n.taskStore.getTaskResult(c)}setCompletionRequestHandler(){this._completionHandlerInitialized||(this.server.assertCanSetRequestHandler(Vs(Cy)),this.server.registerCapabilities({completions:{}}),this.server.setRequestHandler(Cy,async t=>{switch(t.params.ref.type){case"ref/prompt":return EO(t),this.handlePromptCompletion(t,t.params.ref);case"ref/resource":return vO(t),this.handleResourceCompletion(t,t.params.ref);default:throw new me(Ce.InvalidParams,`Invalid completion reference: ${t.params.ref}`)}}),this._completionHandlerInitialized=!0)}async handlePromptCompletion(t,r){let n=this._registeredPrompts[r.name];if(!n)throw new me(Ce.InvalidParams,`Prompt ${r.name} not found`);if(!n.enabled)throw new me(Ce.InvalidParams,`Prompt ${r.name} disabled`);if(!n.argsSchema)return Eh;let o=Ds(n.argsSchema)?.[t.params.argument.name];if(!Wk(o))return Eh;let a=Gq(o);if(!a)return Eh;let s=await a(t.params.argument.value,t.params.context);return Yq(s)}async handleResourceCompletion(t,r){let n=Object.values(this._registeredResourceTemplates).find(a=>a.resourceTemplate.uriTemplate.toString()===r.uri);if(!n){if(this._registeredResources[r.uri])return Eh;throw new me(Ce.InvalidParams,`Resource template ${t.params.ref.uri} not found`)}let i=n.resourceTemplate.completeCallback(t.params.argument.name);if(!i)return Eh;let o=await i(t.params.argument.value,t.params.context);return Yq(o)}setResourceRequestHandlers(){this._resourceHandlersInitialized||(this.server.assertCanSetRequestHandler(Vs(fy)),this.server.assertCanSetRequestHandler(Vs(py)),this.server.assertCanSetRequestHandler(Vs(hy)),this.server.registerCapabilities({resources:{listChanged:!0}}),this.server.setRequestHandler(fy,async(t,r)=>{let n=Object.entries(this._registeredResources).filter(([o,a])=>a.enabled).map(([o,a])=>({uri:o,name:a.name,...a.metadata})),i=[];for(let o of Object.values(this._registeredResourceTemplates)){if(!o.resourceTemplate.listCallback)continue;let a=await o.resourceTemplate.listCallback(r);for(let s of a.resources)i.push({...o.metadata,...s})}return{resources:[...n,...i]}}),this.server.setRequestHandler(py,async()=>({resourceTemplates:Object.entries(this._registeredResourceTemplates).map(([r,n])=>({name:r,uriTemplate:n.resourceTemplate.uriTemplate.toString(),...n.metadata}))})),this.server.setRequestHandler(hy,async(t,r)=>{let n=new URL(t.params.uri),i=this._registeredResources[n.toString()];if(i){if(!i.enabled)throw new me(Ce.InvalidParams,`Resource ${n} disabled`);return i.readCallback(n,r)}for(let o of Object.values(this._registeredResourceTemplates)){let a=o.resourceTemplate.uriTemplate.match(n.toString());if(a)return o.readCallback(n,a,r)}throw new me(Ce.InvalidParams,`Resource ${n} not found`)}),this._resourceHandlersInitialized=!0)}setPromptRequestHandlers(){this._promptHandlersInitialized||(this.server.assertCanSetRequestHandler(Vs(gy)),this.server.assertCanSetRequestHandler(Vs(my)),this.server.registerCapabilities({prompts:{listChanged:!0}}),this.server.setRequestHandler(gy,()=>({prompts:Object.entries(this._registeredPrompts).filter(([,t])=>t.enabled).map(([t,r])=>({name:t,title:r.title,description:r.description,arguments:r.argsSchema?Whe(r.argsSchema):void 0}))})),this.server.setRequestHandler(my,async(t,r)=>{let n=this._registeredPrompts[t.params.name];if(!n)throw new me(Ce.InvalidParams,`Prompt ${t.params.name} not found`);if(!n.enabled)throw new me(Ce.InvalidParams,`Prompt ${t.params.name} disabled`);if(n.argsSchema){let i=sA(n.argsSchema),o=await F0(i,t.params.arguments);if(!o.success){let c="error"in o?o.error:"Unknown error",u=L0(c);throw new me(Ce.InvalidParams,`Invalid arguments for prompt ${t.params.name}: ${u}`)}let a=o.data,s=n.callback;return await Promise.resolve(s(a,r))}else{let i=n.callback;return await Promise.resolve(i(r))}}),this._promptHandlersInitialized=!0)}resource(t,r,...n){let i;typeof n[0]=="object"&&(i=n.shift());let o=n[0];if(typeof r=="string"){if(this._registeredResources[r])throw new Error(`Resource ${r} is already registered`);let a=this._createRegisteredResource(t,void 0,r,i,o);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),a}else{if(this._registeredResourceTemplates[t])throw new Error(`Resource template ${t} is already registered`);let a=this._createRegisteredResourceTemplate(t,void 0,r,i,o);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),a}}registerResource(t,r,n,i){if(typeof r=="string"){if(this._registeredResources[r])throw new Error(`Resource ${r} is already registered`);let o=this._createRegisteredResource(t,n.title,r,n,i);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),o}else{if(this._registeredResourceTemplates[t])throw new Error(`Resource template ${t} is already registered`);let o=this._createRegisteredResourceTemplate(t,n.title,r,n,i);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),o}}_createRegisteredResource(t,r,n,i,o){let a={name:t,title:r,metadata:i,readCallback:o,enabled:!0,disable:()=>a.update({enabled:!1}),enable:()=>a.update({enabled:!0}),remove:()=>a.update({uri:null}),update:s=>{typeof s.uri<"u"&&s.uri!==n&&(delete this._registeredResources[n],s.uri&&(this._registeredResources[s.uri]=a)),typeof s.name<"u"&&(a.name=s.name),typeof s.title<"u"&&(a.title=s.title),typeof s.metadata<"u"&&(a.metadata=s.metadata),typeof s.callback<"u"&&(a.readCallback=s.callback),typeof s.enabled<"u"&&(a.enabled=s.enabled),this.sendResourceListChanged()}};return this._registeredResources[n]=a,a}_createRegisteredResourceTemplate(t,r,n,i,o){let a={resourceTemplate:n,title:r,metadata:i,readCallback:o,enabled:!0,disable:()=>a.update({enabled:!1}),enable:()=>a.update({enabled:!0}),remove:()=>a.update({name:null}),update:u=>{typeof u.name<"u"&&u.name!==t&&(delete this._registeredResourceTemplates[t],u.name&&(this._registeredResourceTemplates[u.name]=a)),typeof u.title<"u"&&(a.title=u.title),typeof u.template<"u"&&(a.resourceTemplate=u.template),typeof u.metadata<"u"&&(a.metadata=u.metadata),typeof u.callback<"u"&&(a.readCallback=u.callback),typeof u.enabled<"u"&&(a.enabled=u.enabled),this.sendResourceListChanged()}};this._registeredResourceTemplates[t]=a;let s=n.uriTemplate.variableNames;return Array.isArray(s)&&s.some(u=>!!n.completeCallback(u))&&this.setCompletionRequestHandler(),a}_createRegisteredPrompt(t,r,n,i,o){let a={title:r,description:n,argsSchema:i===void 0?void 0:ou(i),callback:o,enabled:!0,disable:()=>a.update({enabled:!1}),enable:()=>a.update({enabled:!0}),remove:()=>a.update({name:null}),update:s=>{typeof s.name<"u"&&s.name!==t&&(delete this._registeredPrompts[t],s.name&&(this._registeredPrompts[s.name]=a)),typeof s.title<"u"&&(a.title=s.title),typeof s.description<"u"&&(a.description=s.description),typeof s.argsSchema<"u"&&(a.argsSchema=ou(s.argsSchema)),typeof s.callback<"u"&&(a.callback=s.callback),typeof s.enabled<"u"&&(a.enabled=s.enabled),this.sendPromptListChanged()}};return this._registeredPrompts[t]=a,i&&Object.values(i).some(c=>{let u=c instanceof Dp?c._def?.innerType:c;return Wk(u)})&&this.setCompletionRequestHandler(),a}_createRegisteredTool(t,r,n,i,o,a,s,c,u){Kk(t);let l={title:r,description:n,inputSchema:Hq(i),outputSchema:Hq(o),annotations:a,execution:s,_meta:c,handler:u,enabled:!0,disable:()=>l.update({enabled:!1}),enable:()=>l.update({enabled:!0}),remove:()=>l.update({name:null}),update:A=>{typeof A.name<"u"&&A.name!==t&&(typeof A.name=="string"&&Kk(A.name),delete this._registeredTools[t],A.name&&(this._registeredTools[A.name]=l)),typeof A.title<"u"&&(l.title=A.title),typeof A.description<"u"&&(l.description=A.description),typeof A.paramsSchema<"u"&&(l.inputSchema=ou(A.paramsSchema)),typeof A.outputSchema<"u"&&(l.outputSchema=ou(A.outputSchema)),typeof A.callback<"u"&&(l.handler=A.callback),typeof A.annotations<"u"&&(l.annotations=A.annotations),typeof A._meta<"u"&&(l._meta=A._meta),typeof A.enabled<"u"&&(l.enabled=A.enabled),this.sendToolListChanged()}};return this._registeredTools[t]=l,this.setToolRequestHandlers(),this.sendToolListChanged(),l}tool(t,...r){if(this._registeredTools[t])throw new Error(`Tool ${t} is already registered`);let n,i,o,a;if(typeof r[0]=="string"&&(n=r.shift()),r.length>1){let c=r[0];Xk(c)?(i=r.shift(),r.length>1&&typeof r[0]=="object"&&r[0]!==null&&!Xk(r[0])&&(a=r.shift())):typeof c=="object"&&c!==null&&(a=r.shift())}let s=r[0];return this._createRegisteredTool(t,void 0,n,i,o,a,{taskSupport:"forbidden"},void 0,s)}registerTool(t,r,n){if(this._registeredTools[t])throw new Error(`Tool ${t} is already registered`);let{title:i,description:o,inputSchema:a,outputSchema:s,annotations:c,_meta:u}=r;return this._createRegisteredTool(t,i,o,a,s,c,{taskSupport:"forbidden"},u,n)}prompt(t,...r){if(this._registeredPrompts[t])throw new Error(`Prompt ${t} is already registered`);let n;typeof r[0]=="string"&&(n=r.shift());let i;r.length>1&&(i=r.shift());let o=r[0],a=this._createRegisteredPrompt(t,void 0,n,i,o);return this.setPromptRequestHandlers(),this.sendPromptListChanged(),a}registerPrompt(t,r,n){if(this._registeredPrompts[t])throw new Error(`Prompt ${t} is already registered`);let{title:i,description:o,argsSchema:a}=r,s=this._createRegisteredPrompt(t,i,o,a,n);return this.setPromptRequestHandlers(),this.sendPromptListChanged(),s}isConnected(){return this.server.transport!==void 0}async sendLoggingMessage(t,r){return this.server.sendLoggingMessage(t,r)}sendResourceListChanged(){this.isConnected()&&this.server.sendResourceListChanged()}sendToolListChanged(){this.isConnected()&&this.server.sendToolListChanged()}sendPromptListChanged(){this.isConnected()&&this.server.sendPromptListChanged()}};var Jhe={type:"object",properties:{}};function Jq(e){return e!==null&&typeof e=="object"&&"parse"in e&&typeof e.parse=="function"&&"safeParse"in e&&typeof e.safeParse=="function"}function Zhe(e){return"_def"in e||"_zod"in e||Jq(e)}function Xk(e){return typeof e!="object"||e===null||Zhe(e)?!1:Object.keys(e).length===0?!0:Object.values(e).some(Jq)}function Hq(e){if(e)return Xk(e)?ou(e):e}function Whe(e){let t=Ds(e);return t?Object.entries(t).map(([r,n])=>{let i=eP(n),o=tP(n);return{name:r,description:i,required:!o}}):[]}function Vs(e){let r=Ds(e)?.method;if(!r)throw new Error("Schema is missing a method literal");let n=M0(r);if(typeof n=="string")return n;throw new Error("Schema method literal must be a string")}function Yq(e){return{completion:{values:e.slice(0,100),total:e.length,hasMore:e.length>100}}}var Eh={completion:{values:[],hasMore:!1}};var e1=Pt(require("node:process"),1);var fE=class{append(t){this._buffer=this._buffer?Buffer.concat([this._buffer,t]):t}readMessage(){if(!this._buffer)return null;let t=this._buffer.indexOf(`
|
|
166
166
|
`);if(t===-1)return null;let r=this._buffer.toString("utf8",0,t).replace(/\r$/,"");return this._buffer=this._buffer.subarray(t+1),Khe(r)}clear(){this._buffer=void 0}};function Khe(e){return AO.parse(JSON.parse(e))}function Zq(e){return JSON.stringify(e)+`
|
|
167
|
-
`}var pE=class{constructor(t=e1.default.stdin,r=e1.default.stdout){this._stdin=t,this._stdout=r,this._readBuffer=new fE,this._started=!1,this._ondata=n=>{this._readBuffer.append(n),this.processReadBuffer()},this._onerror=n=>{this.onerror?.(n)}}async start(){if(this._started)throw new Error("StdioServerTransport already started! If using Server class, note that connect() calls start() automatically.");this._started=!0,this._stdin.on("data",this._ondata),this._stdin.on("error",this._onerror)}processReadBuffer(){for(;;)try{let t=this._readBuffer.readMessage();if(t===null)break;this.onmessage?.(t)}catch(t){this.onerror?.(t)}}async close(){this._stdin.off("data",this._ondata),this._stdin.off("error",this._onerror),this._stdin.listenerCount("data")===0&&this._stdin.pause(),this._readBuffer.clear(),this.onclose?.()}send(t){return new Promise(r=>{let n=Zq(t);this._stdout.write(n)?r():this._stdout.once("drain",r)})}};var e5=Pt(Zs());var Gme={error:"error",warn:"warning",info:"info",http:"info",verbose:"debug",debug:"debug",silly:"debug"},kE=class extends e5.default{constructor(r){super(r);de(this,"mcpServer");this.mcpServer=r.mcpServer}async log(r,n){setImmediate(()=>this.emit("logged",r));let{level:i,message:o,...a}=r,s=Gme[i]||"info";try{await this.mcpServer.server.sendLoggingMessage({level:s,data:typeof o=="string"?o:JSON.stringify(o),...a})}catch{}n()}};var a5=Pt(require("path")),s5=Pt(require("os")),c5=Pt(require("fs/promises")),NE=Pt(require("fs"));var ln=[];for(let e=0;e<256;++e)ln.push((e+256).toString(16).slice(1));function t5(e,t=0){return(ln[e[t+0]]+ln[e[t+1]]+ln[e[t+2]]+ln[e[t+3]]+"-"+ln[e[t+4]]+ln[e[t+5]]+"-"+ln[e[t+6]]+ln[e[t+7]]+"-"+ln[e[t+8]]+ln[e[t+9]]+"-"+ln[e[t+10]]+ln[e[t+11]]+ln[e[t+12]]+ln[e[t+13]]+ln[e[t+14]]+ln[e[t+15]]).toLowerCase()}var r5=require("crypto"),RE=new Uint8Array(256),TE=RE.length;function U1(){return TE>RE.length-16&&((0,r5.randomFillSync)(RE),TE=0),RE.slice(TE,TE+=16)}var n5=require("crypto"),F1={randomUUID:n5.randomUUID};function Hme(e,t,r){if(F1.randomUUID&&!t&&!e)return F1.randomUUID();e=e||{};let n=e.random??e.rng?.()??U1();if(n.length<16)throw new Error("Random bytes length must be >= 16");if(n[6]=n[6]&15|64,n[8]=n[8]&63|128,t){if(r=r||0,r<0||r+16>t.length)throw new RangeError(`UUID byte range ${r}:${r+15} is out of buffer bounds`);for(let i=0;i<16;++i)t[r+i]=n[i];return t}return t5(n)}var L1=Hme;var i5=9e4,M1=3;async function o5(e,t,r){for(let n=0;n<M1;n++)try{return await e()}catch(i){let o=Lf(i)&&(i.response?.status??0)>=400&&(i.response?.status??0)<500,a=n+1===M1;if(o||a)throw t.error(`Request failed after ${n+1} attempts, not retrying`,{context:r,error:i instanceof Error?i.message:String(i)}),i;t.warn(`Request failed, retrying (attempt ${n+1}/${M1})`,{context:r,error:i instanceof Error?i.message:String(i)})}throw new Error("Unexpected error in retry logic")}var Jme=We(se({name:U(),description:U(),paramsSchema:bS().optional(),url:U()})),Zme=se({content:U(),files:Gt(U(),se({fileName:U(),fileContentBase64:U()}))}),DE=class{constructor({client:t,logger:r,logLevel:n}){de(this,"mcp");de(this,"logger");de(this,"client");this.logger=r,this.client=t,this.mcp=new dE({name:"Hud",version:"1.0.0"},{capabilities:{logging:{level:n??"info"}}}),r.add(new kE({mcpServer:this.mcp})),r.info("MCP server initialized")}async start(){let t=await this.fetchTools();this.registerTools(t);let r=new pE;this.mcp.connect(r)}async close(){await this.mcp.close()}async fetchTools(){this.logger.debug("Fetching tools");let t=await o5(()=>this.client.get("/mcp/tools",{timeout:i5}),this.logger,"fetchTools");return Jme.parse(t.data).map(n=>({name:n.name,description:n.description,url:n.url,schema:n.paramsSchema?RS(n.paramsSchema):void 0}))}registerTools(t){for(let r of t)this.mcp.registerTool(r.name,{description:r.description,...r.schema?{inputSchema:r.schema}:{}},async n=>await this.handleToolCall(r.name,r.url,n))}async handleToolCall(t,r,n){try{this.logger.debug("Calling tool",{toolName:t,toolUrl:r,args:n});let i=process.env.HUD_MCP_FILELESS==="true",o=await o5(()=>this.client.post(`/mcp/tools/${r}`,n,{headers:i?{"x-hud-fileless-mcp":"true"}:void 0,timeout:i5}),this.logger,"handleToolCall"),a=Zme.parse(o.data);for(let[s,{fileContentBase64:c,fileName:u}]of Object.entries(a.files)){let l=Buffer.from(c,"base64"),A=await Kme(u,l);a.content=a.content.replaceAll(`<${s}>`,A)}return{content:[{type:"text",text:a.content}]}}catch(i){return this.logger.error("Error calling tool",{toolName:t,args:n,msg:i instanceof Error?i.message:`String(err): ${String(i)}`,stack:i instanceof Error?i.stack:void 0}),{content:[{type:"text",text:`Error calling tool: ${i instanceof Error?i.message:`String(err): ${String(i)}`}`}]}}}};function Wme(){let e=process.env.HUD_TEMP_DIRECTORY;return e!==void 0&&e!==""?(NE.existsSync(e)||NE.mkdirSync(e,{recursive:!0}),e):s5.tmpdir()}async function Kme(e,t){let r=Wme(),n=a5.join(r,`hud-${L1()}-${e}`);return await c5.writeFile(n,t),n}var vs=Pt(require("path")),gf=Pt(k3());var T3=Pt(Zs());var Cv=class extends T3.default{constructor(r){super(r);de(this,"axios");this.axios=r.axios}async log(r,n){setImmediate(()=>this.emit("logged",r));try{await this.axios.post("/",r)}catch{}n()}};var OA="2.0.
|
|
167
|
+
`}var pE=class{constructor(t=e1.default.stdin,r=e1.default.stdout){this._stdin=t,this._stdout=r,this._readBuffer=new fE,this._started=!1,this._ondata=n=>{this._readBuffer.append(n),this.processReadBuffer()},this._onerror=n=>{this.onerror?.(n)}}async start(){if(this._started)throw new Error("StdioServerTransport already started! If using Server class, note that connect() calls start() automatically.");this._started=!0,this._stdin.on("data",this._ondata),this._stdin.on("error",this._onerror)}processReadBuffer(){for(;;)try{let t=this._readBuffer.readMessage();if(t===null)break;this.onmessage?.(t)}catch(t){this.onerror?.(t)}}async close(){this._stdin.off("data",this._ondata),this._stdin.off("error",this._onerror),this._stdin.listenerCount("data")===0&&this._stdin.pause(),this._readBuffer.clear(),this.onclose?.()}send(t){return new Promise(r=>{let n=Zq(t);this._stdout.write(n)?r():this._stdout.once("drain",r)})}};var e5=Pt(Zs());var Gme={error:"error",warn:"warning",info:"info",http:"info",verbose:"debug",debug:"debug",silly:"debug"},kE=class extends e5.default{constructor(r){super(r);de(this,"mcpServer");this.mcpServer=r.mcpServer}async log(r,n){setImmediate(()=>this.emit("logged",r));let{level:i,message:o,...a}=r,s=Gme[i]||"info";try{await this.mcpServer.server.sendLoggingMessage({level:s,data:typeof o=="string"?o:JSON.stringify(o),...a})}catch{}n()}};var a5=Pt(require("path")),s5=Pt(require("os")),c5=Pt(require("fs/promises")),NE=Pt(require("fs"));var ln=[];for(let e=0;e<256;++e)ln.push((e+256).toString(16).slice(1));function t5(e,t=0){return(ln[e[t+0]]+ln[e[t+1]]+ln[e[t+2]]+ln[e[t+3]]+"-"+ln[e[t+4]]+ln[e[t+5]]+"-"+ln[e[t+6]]+ln[e[t+7]]+"-"+ln[e[t+8]]+ln[e[t+9]]+"-"+ln[e[t+10]]+ln[e[t+11]]+ln[e[t+12]]+ln[e[t+13]]+ln[e[t+14]]+ln[e[t+15]]).toLowerCase()}var r5=require("crypto"),RE=new Uint8Array(256),TE=RE.length;function U1(){return TE>RE.length-16&&((0,r5.randomFillSync)(RE),TE=0),RE.slice(TE,TE+=16)}var n5=require("crypto"),F1={randomUUID:n5.randomUUID};function Hme(e,t,r){if(F1.randomUUID&&!t&&!e)return F1.randomUUID();e=e||{};let n=e.random??e.rng?.()??U1();if(n.length<16)throw new Error("Random bytes length must be >= 16");if(n[6]=n[6]&15|64,n[8]=n[8]&63|128,t){if(r=r||0,r<0||r+16>t.length)throw new RangeError(`UUID byte range ${r}:${r+15} is out of buffer bounds`);for(let i=0;i<16;++i)t[r+i]=n[i];return t}return t5(n)}var L1=Hme;var i5=9e4,M1=3;async function o5(e,t,r){for(let n=0;n<M1;n++)try{return await e()}catch(i){let o=Lf(i)&&(i.response?.status??0)>=400&&(i.response?.status??0)<500,a=n+1===M1;if(o||a)throw t.error(`Request failed after ${n+1} attempts, not retrying`,{context:r,error:i instanceof Error?i.message:String(i)}),i;t.warn(`Request failed, retrying (attempt ${n+1}/${M1})`,{context:r,error:i instanceof Error?i.message:String(i)})}throw new Error("Unexpected error in retry logic")}var Jme=We(se({name:U(),description:U(),paramsSchema:bS().optional(),url:U()})),Zme=se({content:U(),files:Gt(U(),se({fileName:U(),fileContentBase64:U()}))}),DE=class{constructor({client:t,logger:r,logLevel:n}){de(this,"mcp");de(this,"logger");de(this,"client");this.logger=r,this.client=t,this.mcp=new dE({name:"Hud",version:"1.0.0"},{capabilities:{logging:{level:n??"info"}}}),r.add(new kE({mcpServer:this.mcp})),r.info("MCP server initialized")}async start(){let t=await this.fetchTools();this.registerTools(t);let r=new pE;this.mcp.connect(r)}async close(){await this.mcp.close()}async fetchTools(){this.logger.debug("Fetching tools");let t=await o5(()=>this.client.get("/mcp/tools",{timeout:i5}),this.logger,"fetchTools");return Jme.parse(t.data).map(n=>({name:n.name,description:n.description,url:n.url,schema:n.paramsSchema?RS(n.paramsSchema):void 0}))}registerTools(t){for(let r of t)this.mcp.registerTool(r.name,{description:r.description,...r.schema?{inputSchema:r.schema}:{}},async n=>await this.handleToolCall(r.name,r.url,n))}async handleToolCall(t,r,n){try{this.logger.debug("Calling tool",{toolName:t,toolUrl:r,args:n});let i=process.env.HUD_MCP_FILELESS==="true",o=await o5(()=>this.client.post(`/mcp/tools/${r}`,n,{headers:i?{"x-hud-fileless-mcp":"true"}:void 0,timeout:i5}),this.logger,"handleToolCall"),a=Zme.parse(o.data);for(let[s,{fileContentBase64:c,fileName:u}]of Object.entries(a.files)){let l=Buffer.from(c,"base64"),A=await Kme(u,l);a.content=a.content.replaceAll(`<${s}>`,A)}return{content:[{type:"text",text:a.content}]}}catch(i){return this.logger.error("Error calling tool",{toolName:t,args:n,msg:i instanceof Error?i.message:`String(err): ${String(i)}`,stack:i instanceof Error?i.stack:void 0}),{content:[{type:"text",text:`Error calling tool: ${i instanceof Error?i.message:`String(err): ${String(i)}`}`}]}}}};function Wme(){let e=process.env.HUD_TEMP_DIRECTORY;return e!==void 0&&e!==""?(NE.existsSync(e)||NE.mkdirSync(e,{recursive:!0}),e):s5.tmpdir()}async function Kme(e,t){let r=Wme(),n=a5.join(r,`hud-${L1()}-${e}`);return await c5.writeFile(n,t),n}var vs=Pt(require("path")),gf=Pt(k3());var T3=Pt(Zs());var Cv=class extends T3.default{constructor(r){super(r);de(this,"axios");this.axios=r.axios}async log(r,n){setImmediate(()=>this.emit("logged",r));try{await this.axios.post("/",r)}catch{}n()}};var OA="2.0.2";var Yee=Pt(kee()),Jee=Pt(Vee());function RFe(e){return["mcp__hud__","mcp__hud-ng__"].some(r=>e.startsWith(r))}function DFe(e){return e.startsWith("MCP:hud-")}async function jee(){return new Promise((e,t)=>{let r="",n=setTimeout(()=>t(new Error("stdin timeout")),5e3);process.stdin.setEncoding("utf8"),process.stdin.on("data",i=>r+=i),process.stdin.on("end",()=>{clearTimeout(n),e(r)}),process.stdin.on("error",t)})}function hf(e){process.stdout.write(JSON.stringify(e))}function NFe(e){let t=e.tool_input.usageAnalytics,r={model:e.model,conversation_id:e.conversation_id,generation_id:e.generation_id,originalUsageAnalytics:t};return{...e.tool_input,usageAnalytics:JSON.stringify(r)}}async function Gee(){try{let e=await jee(),t=JSON.parse(e);if(!DFe(t.tool_name)){hf({decision:"allow"});return}let r=NFe(t);hf({decision:"allow",updated_input:r})}catch(e){console.error("HUD Cursor hook error:",e),hf({decision:"allow"})}}function UFe(e){let t=e.tool_input.usageAnalytics,r={session_id:e.session_id,originalUsageAnalytics:t};return{...e.tool_input,usageAnalytics:JSON.stringify(r)}}async function Hee(){try{let e=await jee(),t=JSON.parse(e);if(!RFe(t.tool_name)){hf({hookSpecificOutput:{hookEventName:"PreToolUse",permissionDecision:"allow"}});return}let n={hookSpecificOutput:{hookEventName:"PreToolUse",permissionDecision:"allow",updatedInput:UFe(t)}};hf(n)}catch(e){console.error("HUD Claude hook error:",e),hf({hookSpecificOutput:{hookEventName:"PreToolUse",permissionDecision:"allow"}})}}function FFe(){let e=process.env.HUD_MCP_CONFIG_PATH;return e!==void 0?e:vs.join(hm.homedir(),".hud","config.json")}function dU(){return process.env.MCP_LOGS_DIRECTORY?process.env.MCP_LOGS_DIRECTORY:vs.join(hm.homedir(),".hud","logs")}function LFe(){return vs.join(dU(),"mcp.log")}function MFe(){let e=vs.join(hm.homedir(),".hud","ready.json");lo.writeFileSync(e,JSON.stringify({timestamp:new Date().toISOString(),version:OA}))}function $Fe(){let e=process.env.WORKSPACE_NAME_KEY;if(!e)return[];try{let t=vs.join(hm.homedir(),".hud","services-mapping.json");return lo.existsSync(t)?JSON.parse(lo.readFileSync(t,"utf8"))[e]?.services??[]:[]}catch{return[]}}var AU;function Zee(){let e=FFe(),t={accessToken:"",baseUrl:"https://api-prod.hud.io",logEndpoint:"https://yqp37dddrsewm6wdwwpwfraxqm0shdmx.lambda-url.eu-central-1.on.aws"};try{if(lo.existsSync(e)){let n=lo.readFileSync(e,"utf8");t={...t,...JSON.parse(n)}}}catch{}let r=process.env.HUD_MCP_BASE_URL;return r!==void 0&&r!==""&&(t.baseUrl=r),AU&&(t.accessToken=AU),t}function PFe(e){let t=new Date().toISOString().replace(/[:.]/g,"-"),r=dU(),n=vs.join(r,`mcp-crash-${t}.log`),i;if(e instanceof Error){if(i=`Error Name: ${e.name}
|
|
168
168
|
Message: ${e.message}
|
|
169
169
|
Stack: ${e.stack}
|
|
170
170
|
`,Lf(e)){let a=e;a.response&&(i+=`
|