@anthropic-ai/claude-agent-sdk 0.2.34 → 0.2.36
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/cli.js +1555 -1552
- package/manifest.json +16 -16
- package/package.json +2 -2
- package/sdk.mjs +2 -2
package/manifest.json
CHANGED
|
@@ -1,41 +1,41 @@
|
|
|
1
1
|
{
|
|
2
|
-
"version": "2.1.
|
|
3
|
-
"buildDate": "2026-02-
|
|
2
|
+
"version": "2.1.36",
|
|
3
|
+
"buildDate": "2026-02-07T17:26:17Z",
|
|
4
4
|
"platforms": {
|
|
5
5
|
"darwin-arm64": {
|
|
6
6
|
"binary": "claude",
|
|
7
|
-
"checksum": "
|
|
8
|
-
"size":
|
|
7
|
+
"checksum": "13da8af753ec246d0992ada508de059b3ad50712708155d4a3450c18ad6115e4",
|
|
8
|
+
"size": 181423280
|
|
9
9
|
},
|
|
10
10
|
"darwin-x64": {
|
|
11
11
|
"binary": "claude",
|
|
12
|
-
"checksum": "
|
|
13
|
-
"size":
|
|
12
|
+
"checksum": "79148e2bacaf3917f75e8cbf90cd3f74187a1f5f10a6216a2dc8bc84fc15ad6c",
|
|
13
|
+
"size": 186482592
|
|
14
14
|
},
|
|
15
15
|
"linux-arm64": {
|
|
16
16
|
"binary": "claude",
|
|
17
|
-
"checksum": "
|
|
18
|
-
"size":
|
|
17
|
+
"checksum": "c01e68cb303f0edef3619da68e58f15a3b9638e4db936eaee644ec326e603aa3",
|
|
18
|
+
"size": 218580546
|
|
19
19
|
},
|
|
20
20
|
"linux-x64": {
|
|
21
21
|
"binary": "claude",
|
|
22
|
-
"checksum": "
|
|
23
|
-
"size":
|
|
22
|
+
"checksum": "3466e6f86be62a60d761de096290dd9045cb295c4e4011a0737449c2c8400aa5",
|
|
23
|
+
"size": 221421583
|
|
24
24
|
},
|
|
25
25
|
"linux-arm64-musl": {
|
|
26
26
|
"binary": "claude",
|
|
27
|
-
"checksum": "
|
|
28
|
-
"size":
|
|
27
|
+
"checksum": "80a58f6ffc96315ade8a14b3d9d62bf645e9827ccd22856332fb4d21bc2e3f4e",
|
|
28
|
+
"size": 211763938
|
|
29
29
|
},
|
|
30
30
|
"linux-x64-musl": {
|
|
31
31
|
"binary": "claude",
|
|
32
|
-
"checksum": "
|
|
33
|
-
"size":
|
|
32
|
+
"checksum": "f23646a11e289fd2aaa2df50317e30c1cec5f0000c056b485b8d05f3a7226e11",
|
|
33
|
+
"size": 213921639
|
|
34
34
|
},
|
|
35
35
|
"win32-x64": {
|
|
36
36
|
"binary": "claude.exe",
|
|
37
|
-
"checksum": "
|
|
38
|
-
"size":
|
|
37
|
+
"checksum": "0621b6236f2edd5d07557dc3530f6f9a92c515d33f857f83980697e555d04e73",
|
|
38
|
+
"size": 231149216
|
|
39
39
|
}
|
|
40
40
|
}
|
|
41
41
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@anthropic-ai/claude-agent-sdk",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.36",
|
|
4
4
|
"main": "sdk.mjs",
|
|
5
5
|
"types": "sdk.d.ts",
|
|
6
6
|
"engines": {
|
|
@@ -37,5 +37,5 @@
|
|
|
37
37
|
"@img/sharp-linuxmusl-x64": "^0.33.5",
|
|
38
38
|
"@img/sharp-win32-x64": "^0.33.5"
|
|
39
39
|
},
|
|
40
|
-
"claudeCodeVersion": "2.1.
|
|
40
|
+
"claudeCodeVersion": "2.1.36"
|
|
41
41
|
}
|
package/sdk.mjs
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
// (c) Anthropic PBC. All rights reserved. Use is subject to the Legal Agreements outlined here: https://code.claude.com/docs/en/legal-and-compliance.
|
|
3
3
|
|
|
4
|
-
// Version: 0.2.
|
|
4
|
+
// Version: 0.2.36
|
|
5
5
|
|
|
6
6
|
// Want to see the unminified source? We're hiring!
|
|
7
7
|
// https://job-boards.greenhouse.io/anthropic/jobs/4816199008
|
|
@@ -52,5 +52,5 @@ Set the \`cycles\` parameter to \`"ref"\` to resolve cyclical schemas with defs.
|
|
|
52
52
|
]))`;continue}else if(Y[B]==="$"){W+=`($|(?=[\r
|
|
53
53
|
]))`;continue}}if($.s&&Y[B]==="."){W+=G?`${Y[B]}\r
|
|
54
54
|
`:`[${Y[B]}\r
|
|
55
|
-
]`;continue}if(W+=Y[B],Y[B]==="\\")J=!0;else if(G&&Y[B]==="]")G=!1;else if(!G&&Y[B]==="[")G=!0}try{new RegExp(W)}catch{return console.warn(`Could not convert regex pattern at ${Q.currentPath.join("/")} to a flag-independent form! Falling back to the flag-ignorant source`),X.source}return W}function O8(X,Q){if(Q.target==="openAi")console.warn("Warning: OpenAI may not support records in schemas! Try an array of key-value pairs instead.");if(Q.target==="openApi3"&&X.keyType?._def.typeName===j.ZodEnum)return{type:"object",required:X.keyType._def.values,properties:X.keyType._def.values.reduce((Y,W)=>({...Y,[W]:f(X.valueType._def,{...Q,currentPath:[...Q.currentPath,"properties",W]})??B0(Q)}),{}),additionalProperties:Q.rejectedAdditionalProperties};let $={type:"object",additionalProperties:f(X.valueType._def,{...Q,currentPath:[...Q.currentPath,"additionalProperties"]})??Q.allowedAdditionalProperties};if(Q.target==="openApi3")return $;if(X.keyType?._def.typeName===j.ZodString&&X.keyType._def.checks?.length){let{type:Y,...W}=N8(X.keyType._def,Q);return{...$,propertyNames:W}}else if(X.keyType?._def.typeName===j.ZodEnum)return{...$,propertyNames:{enum:X.keyType._def.values}};else if(X.keyType?._def.typeName===j.ZodBranded&&X.keyType._def.type._def.typeName===j.ZodString&&X.keyType._def.type._def.checks?.length){let{type:Y,...W}=F8(X.keyType._def,Q);return{...$,propertyNames:W}}return $}function g5(X,Q){if(Q.mapStrategy==="record")return O8(X,Q);let $=f(X.keyType._def,{...Q,currentPath:[...Q.currentPath,"items","items","0"]})||B0(Q),Y=f(X.valueType._def,{...Q,currentPath:[...Q.currentPath,"items","items","1"]})||B0(Q);return{type:"array",maxItems:125,items:{type:"array",items:[$,Y],minItems:2,maxItems:2}}}function f5(X){let Q=X.values,Y=Object.keys(X.values).filter((J)=>{return typeof Q[Q[J]]!=="number"}).map((J)=>Q[J]),W=Array.from(new Set(Y.map((J)=>typeof J)));return{type:W.length===1?W[0]==="string"?"string":"number":["string","number"],enum:Y}}function h5(X){return X.target==="openAi"?void 0:{not:B0({...X,currentPath:[...X.currentPath,"not"]})}}function u5(X){return X.target==="openApi3"?{enum:["null"],nullable:!0}:{type:"null"}}var gX={ZodString:"string",ZodNumber:"number",ZodBigInt:"integer",ZodBoolean:"boolean",ZodNull:"null"};function m5(X,Q){if(Q.target==="openApi3")return l5(X,Q);let $=X.options instanceof Map?Array.from(X.options.values()):X.options;if($.every((Y)=>(Y._def.typeName in gX)&&(!Y._def.checks||!Y._def.checks.length))){let Y=$.reduce((W,J)=>{let G=gX[J._def.typeName];return G&&!W.includes(G)?[...W,G]:W},[]);return{type:Y.length>1?Y:Y[0]}}else if($.every((Y)=>Y._def.typeName==="ZodLiteral"&&!Y.description)){let Y=$.reduce((W,J)=>{let G=typeof J._def.value;switch(G){case"string":case"number":case"boolean":return[...W,G];case"bigint":return[...W,"integer"];case"object":if(J._def.value===null)return[...W,"null"];case"symbol":case"undefined":case"function":default:return W}},[]);if(Y.length===$.length){let W=Y.filter((J,G,H)=>H.indexOf(J)===G);return{type:W.length>1?W:W[0],enum:$.reduce((J,G)=>{return J.includes(G._def.value)?J:[...J,G._def.value]},[])}}}else if($.every((Y)=>Y._def.typeName==="ZodEnum"))return{type:"string",enum:$.reduce((Y,W)=>[...Y,...W._def.values.filter((J)=>!Y.includes(J))],[])};return l5(X,Q)}var l5=(X,Q)=>{let $=(X.options instanceof Map?Array.from(X.options.values()):X.options).map((Y,W)=>f(Y._def,{...Q,currentPath:[...Q.currentPath,"anyOf",`${W}`]})).filter((Y)=>!!Y&&(!Q.strictUnions||typeof Y==="object"&&Object.keys(Y).length>0));return $.length?{anyOf:$}:void 0};function c5(X,Q){if(["ZodString","ZodNumber","ZodBigInt","ZodBoolean","ZodNull"].includes(X.innerType._def.typeName)&&(!X.innerType._def.checks||!X.innerType._def.checks.length)){if(Q.target==="openApi3")return{type:gX[X.innerType._def.typeName],nullable:!0};return{type:[gX[X.innerType._def.typeName],"null"]}}if(Q.target==="openApi3"){let Y=f(X.innerType._def,{...Q,currentPath:[...Q.currentPath]});if(Y&&"$ref"in Y)return{allOf:[Y],nullable:!0};return Y&&{...Y,nullable:!0}}let $=f(X.innerType._def,{...Q,currentPath:[...Q.currentPath,"anyOf","0"]});return $&&{anyOf:[$,{type:"null"}]}}function p5(X,Q){let $={type:"number"};if(!X.checks)return $;for(let Y of X.checks)switch(Y.kind){case"int":$.type="integer",m$($,"type",Y.message,Q);break;case"min":if(Q.target==="jsonSchema7")if(Y.inclusive)o($,"minimum",Y.value,Y.message,Q);else o($,"exclusiveMinimum",Y.value,Y.message,Q);else{if(!Y.inclusive)$.exclusiveMinimum=!0;o($,"minimum",Y.value,Y.message,Q)}break;case"max":if(Q.target==="jsonSchema7")if(Y.inclusive)o($,"maximum",Y.value,Y.message,Q);else o($,"exclusiveMaximum",Y.value,Y.message,Q);else{if(!Y.inclusive)$.exclusiveMaximum=!0;o($,"maximum",Y.value,Y.message,Q)}break;case"multipleOf":o($,"multipleOf",Y.value,Y.message,Q);break}return $}function d5(X,Q){let $=Q.target==="openAi",Y={type:"object",properties:{}},W=[],J=X.shape();for(let H in J){let B=J[H];if(B===void 0||B._def===void 0)continue;let z=VN(B);if(z&&$){if(B._def.typeName==="ZodOptional")B=B._def.innerType;if(!B.isNullable())B=B.nullable();z=!1}let K=f(B._def,{...Q,currentPath:[...Q.currentPath,"properties",H],propertyPath:[...Q.currentPath,"properties",H]});if(K===void 0)continue;if(Y.properties[H]=K,!z)W.push(H)}if(W.length)Y.required=W;let G=UN(X,Q);if(G!==void 0)Y.additionalProperties=G;return Y}function UN(X,Q){if(X.catchall._def.typeName!=="ZodNever")return f(X.catchall._def,{...Q,currentPath:[...Q.currentPath,"additionalProperties"]});switch(X.unknownKeys){case"passthrough":return Q.allowedAdditionalProperties;case"strict":return Q.rejectedAdditionalProperties;case"strip":return Q.removeAdditionalStrategy==="strict"?Q.allowedAdditionalProperties:Q.rejectedAdditionalProperties}}function VN(X){try{return X.isOptional()}catch{return!0}}var i5=(X,Q)=>{if(Q.currentPath.toString()===Q.propertyPath?.toString())return f(X.innerType._def,Q);let $=f(X.innerType._def,{...Q,currentPath:[...Q.currentPath,"anyOf","1"]});return $?{anyOf:[{not:B0(Q)},$]}:B0(Q)};var n5=(X,Q)=>{if(Q.pipeStrategy==="input")return f(X.in._def,Q);else if(Q.pipeStrategy==="output")return f(X.out._def,Q);let $=f(X.in._def,{...Q,currentPath:[...Q.currentPath,"allOf","0"]}),Y=f(X.out._def,{...Q,currentPath:[...Q.currentPath,"allOf",$?"1":"0"]});return{allOf:[$,Y].filter((W)=>W!==void 0)}};function r5(X,Q){return f(X.type._def,Q)}function o5(X,Q){let Y={type:"array",uniqueItems:!0,items:f(X.valueType._def,{...Q,currentPath:[...Q.currentPath,"items"]})};if(X.minSize)o(Y,"minItems",X.minSize.value,X.minSize.message,Q);if(X.maxSize)o(Y,"maxItems",X.maxSize.value,X.maxSize.message,Q);return Y}function t5(X,Q){if(X.rest)return{type:"array",minItems:X.items.length,items:X.items.map(($,Y)=>f($._def,{...Q,currentPath:[...Q.currentPath,"items",`${Y}`]})).reduce(($,Y)=>Y===void 0?$:[...$,Y],[]),additionalItems:f(X.rest._def,{...Q,currentPath:[...Q.currentPath,"additionalItems"]})};else return{type:"array",minItems:X.items.length,maxItems:X.items.length,items:X.items.map(($,Y)=>f($._def,{...Q,currentPath:[...Q.currentPath,"items",`${Y}`]})).reduce(($,Y)=>Y===void 0?$:[...$,Y],[])}}function a5(X){return{not:B0(X)}}function s5(X){return B0(X)}var e5=(X,Q)=>{return f(X.innerType._def,Q)};var XG=(X,Q,$)=>{switch(Q){case j.ZodString:return N8(X,$);case j.ZodNumber:return p5(X,$);case j.ZodObject:return d5(X,$);case j.ZodBigInt:return S5(X,$);case j.ZodBoolean:return Z5();case j.ZodDate:return c$(X,$);case j.ZodUndefined:return a5($);case j.ZodNull:return u5($);case j.ZodArray:return P5(X,$);case j.ZodUnion:case j.ZodDiscriminatedUnion:return m5(X,$);case j.ZodIntersection:return _5(X,$);case j.ZodTuple:return t5(X,$);case j.ZodRecord:return O8(X,$);case j.ZodLiteral:return x5(X,$);case j.ZodEnum:return T5(X);case j.ZodNativeEnum:return f5(X);case j.ZodNullable:return c5(X,$);case j.ZodOptional:return i5(X,$);case j.ZodMap:return g5(X,$);case j.ZodSet:return o5(X,$);case j.ZodLazy:return()=>X.getter()._def;case j.ZodPromise:return r5(X,$);case j.ZodNaN:case j.ZodNever:return h5($);case j.ZodEffects:return v5(X,$);case j.ZodAny:return B0($);case j.ZodUnknown:return s5($);case j.ZodDefault:return k5(X,$);case j.ZodBranded:return F8(X,$);case j.ZodReadonly:return e5(X,$);case j.ZodCatch:return C5(X,$);case j.ZodPipeline:return n5(X,$);case j.ZodFunction:case j.ZodVoid:case j.ZodSymbol:return;default:return((Y)=>{return})(Q)}};function f(X,Q,$=!1){let Y=Q.seen.get(X);if(Q.override){let H=Q.override?.(X,Q,Y,$);if(H!==I5)return H}if(Y&&!$){let H=LN(Y,Q);if(H!==void 0)return H}let W={def:X,path:Q.currentPath,jsonSchema:void 0};Q.seen.set(X,W);let J=XG(X,X.typeName,Q),G=typeof J==="function"?f(J(),Q):J;if(G)qN(X,Q,G);if(Q.postProcess){let H=Q.postProcess(G,X,Q);return W.jsonSchema=G,H}return W.jsonSchema=G,G}var LN=(X,Q)=>{switch(Q.$refStrategy){case"root":return{$ref:X.path.join("/")};case"relative":return{$ref:q8(Q.currentPath,X.path)};case"none":case"seen":{if(X.path.length<Q.currentPath.length&&X.path.every(($,Y)=>Q.currentPath[Y]===$))return console.warn(`Recursive reference detected at ${Q.currentPath.join("/")}! Defaulting to any`),B0(Q);return Q.$refStrategy==="seen"?B0(Q):void 0}}},qN=(X,Q,$)=>{if(X.description){if($.description=X.description,Q.markdownDescription)$.markdownDescription=X.description}return $};var i$=(X,Q)=>{let $=b5(Q),Y=typeof Q==="object"&&Q.definitions?Object.entries(Q.definitions).reduce((B,[z,K])=>({...B,[z]:f(K._def,{...$,currentPath:[...$.basePath,$.definitionPath,z]},!0)??B0($)}),{}):void 0,W=typeof Q==="string"?Q:Q?.nameStrategy==="title"?void 0:Q?.name,J=f(X._def,W===void 0?$:{...$,currentPath:[...$.basePath,$.definitionPath,W]},!1)??B0($),G=typeof Q==="object"&&Q.name!==void 0&&Q.nameStrategy==="title"?Q.name:void 0;if(G!==void 0)J.title=G;if($.flags.hasReferencedOpenAiAnyType){if(!Y)Y={};if(!Y[$.openAiAnyTypeName])Y[$.openAiAnyTypeName]={type:["string","number","integer","boolean","array","null"],items:{$ref:$.$refStrategy==="relative"?"1":[...$.basePath,$.definitionPath,$.openAiAnyTypeName].join("/")}}}let H=W===void 0?Y?{...J,[$.definitionPath]:Y}:J:{$ref:[...$.$refStrategy==="relative"?[]:$.basePath,$.definitionPath,W].join("/"),[$.definitionPath]:{...Y,[W]:J}};if($.target==="jsonSchema7")H.$schema="http://json-schema.org/draft-07/schema#";else if($.target==="jsonSchema2019-09"||$.target==="openAi")H.$schema="https://json-schema.org/draft/2019-09/schema#";if($.target==="openAi"&&(("anyOf"in H)||("oneOf"in H)||("allOf"in H)||("type"in H)&&Array.isArray(H.type)))console.warn("Warning: OpenAI may not support schemas with unions as roots! Try wrapping it in an object property.");return H};function FN(X){if(!X)return"draft-7";if(X==="jsonSchema7"||X==="draft-7")return"draft-7";if(X==="jsonSchema2019-09"||X==="draft-2020-12")return"draft-2020-12";return"draft-7"}function n$(X,Q){var $,Y,W;if(m0(X))return N$(X,{target:FN(Q===null||Q===void 0?void 0:Q.target),io:($=Q===null||Q===void 0?void 0:Q.pipeStrategy)!==null&&$!==void 0?$:"input"});return i$(X,{strictUnions:(Y=Q===null||Q===void 0?void 0:Q.strictUnions)!==null&&Y!==void 0?Y:!0,pipeStrategy:(W=Q===null||Q===void 0?void 0:Q.pipeStrategy)!==null&&W!==void 0?W:"input"})}function r$(X){let Q=h1(X),$=Q===null||Q===void 0?void 0:Q.method;if(!$)throw Error("Schema is missing a method literal");let Y=p4($);if(typeof Y!=="string")throw Error("Schema method literal must be a string");return Y}function o$(X,Q){let $=f1(X,Q);if(!$.success)throw $.error;return $.data}var NN=60000;class t${constructor(X){if(this._options=X,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(a4,(Q)=>{this._oncancel(Q)}),this.setNotificationHandler(e4,(Q)=>{this._onprogress(Q)}),this.setRequestHandler(s4,(Q)=>({})),this._taskStore=X===null||X===void 0?void 0:X.taskStore,this._taskMessageQueue=X===null||X===void 0?void 0:X.taskMessageQueue,this._taskStore)this.setRequestHandler(X8,async(Q,$)=>{let Y=await this._taskStore.getTask(Q.params.taskId,$.sessionId);if(!Y)throw new k(x.InvalidParams,"Failed to retrieve task: Task not found");return{...Y}}),this.setRequestHandler($8,async(Q,$)=>{let Y=async()=>{var W;let J=Q.params.taskId;if(this._taskMessageQueue){let H;while(H=await this._taskMessageQueue.dequeue(J,$.sessionId)){if(H.type==="response"||H.type==="error"){let B=H.message,z=B.id,K=this._requestResolvers.get(z);if(K)if(this._requestResolvers.delete(z),H.type==="response")K(B);else{let V=B,L=new k(V.error.code,V.error.message,V.error.data);K(L)}else{let V=H.type==="response"?"Response":"Error";this._onerror(Error(`${V} handler missing for request ${z}`))}continue}await((W=this._transport)===null||W===void 0?void 0:W.send(H.message,{relatedRequestId:$.requestId}))}}let G=await this._taskStore.getTask(J,$.sessionId);if(!G)throw new k(x.InvalidParams,`Task not found: ${J}`);if(!u1(G.status))return await this._waitForTaskUpdate(J,$.signal),await Y();if(u1(G.status)){let H=await this._taskStore.getTaskResult(J,$.sessionId);return this._clearTaskQueue(J),{...H,_meta:{...H._meta,[z1]:{taskId:J}}}}return await Y()};return await Y()}),this.setRequestHandler(Y8,async(Q,$)=>{var Y;try{let{tasks:W,nextCursor:J}=await this._taskStore.listTasks((Y=Q.params)===null||Y===void 0?void 0:Y.cursor,$.sessionId);return{tasks:W,nextCursor:J,_meta:{}}}catch(W){throw new k(x.InvalidParams,`Failed to list tasks: ${W instanceof Error?W.message:String(W)}`)}}),this.setRequestHandler(L5,async(Q,$)=>{try{let Y=await this._taskStore.getTask(Q.params.taskId,$.sessionId);if(!Y)throw new k(x.InvalidParams,`Task not found: ${Q.params.taskId}`);if(u1(Y.status))throw new k(x.InvalidParams,`Cannot cancel task in terminal status: ${Y.status}`);await this._taskStore.updateTaskStatus(Q.params.taskId,"cancelled","Client cancelled task execution.",$.sessionId),this._clearTaskQueue(Q.params.taskId);let W=await this._taskStore.getTask(Q.params.taskId,$.sessionId);if(!W)throw new k(x.InvalidParams,`Task not found after cancellation: ${Q.params.taskId}`);return{_meta:{},...W}}catch(Y){if(Y instanceof k)throw Y;throw new k(x.InvalidRequest,`Failed to cancel task: ${Y instanceof Error?Y.message:String(Y)}`)}})}async _oncancel(X){let Q=this._requestHandlerAbortControllers.get(X.params.requestId);Q===null||Q===void 0||Q.abort(X.params.reason)}_setupTimeout(X,Q,$,Y,W=!1){this._timeoutInfo.set(X,{timeoutId:setTimeout(Y,Q),startTime:Date.now(),timeout:Q,maxTotalTimeout:$,resetTimeoutOnProgress:W,onTimeout:Y})}_resetTimeout(X){let Q=this._timeoutInfo.get(X);if(!Q)return!1;let $=Date.now()-Q.startTime;if(Q.maxTotalTimeout&&$>=Q.maxTotalTimeout)throw this._timeoutInfo.delete(X),k.fromError(x.RequestTimeout,"Maximum total timeout exceeded",{maxTotalTimeout:Q.maxTotalTimeout,totalElapsed:$});return clearTimeout(Q.timeoutId),Q.timeoutId=setTimeout(Q.onTimeout,Q.timeout),!0}_cleanupTimeout(X){let Q=this._timeoutInfo.get(X);if(Q)clearTimeout(Q.timeoutId),this._timeoutInfo.delete(X)}async connect(X){var Q,$,Y;this._transport=X;let W=(Q=this.transport)===null||Q===void 0?void 0:Q.onclose;this._transport.onclose=()=>{W===null||W===void 0||W(),this._onclose()};let J=($=this.transport)===null||$===void 0?void 0:$.onerror;this._transport.onerror=(H)=>{J===null||J===void 0||J(H),this._onerror(H)};let G=(Y=this._transport)===null||Y===void 0?void 0:Y.onmessage;this._transport.onmessage=(H,B)=>{if(G===null||G===void 0||G(H,B),CX(H)||U5(H))this._onresponse(H);else if(Z$(H))this._onrequest(H,B);else if(B5(H))this._onnotification(H);else this._onerror(Error(`Unknown message type: ${JSON.stringify(H)}`))},await this._transport.start()}_onclose(){var X;let Q=this._responseHandlers;this._responseHandlers=new Map,this._progressHandlers.clear(),this._taskProgressTokens.clear(),this._pendingDebouncedNotifications.clear();let $=k.fromError(x.ConnectionClosed,"Connection closed");this._transport=void 0,(X=this.onclose)===null||X===void 0||X.call(this);for(let Y of Q.values())Y($)}_onerror(X){var Q;(Q=this.onerror)===null||Q===void 0||Q.call(this,X)}_onnotification(X){var Q;let $=(Q=this._notificationHandlers.get(X.method))!==null&&Q!==void 0?Q:this.fallbackNotificationHandler;if($===void 0)return;Promise.resolve().then(()=>$(X)).catch((Y)=>this._onerror(Error(`Uncaught error in notification handler: ${Y}`)))}_onrequest(X,Q){var $,Y,W,J,G,H;let B=($=this._requestHandlers.get(X.method))!==null&&$!==void 0?$:this.fallbackRequestHandler,z=this._transport,K=(J=(W=(Y=X.params)===null||Y===void 0?void 0:Y._meta)===null||W===void 0?void 0:W[z1])===null||J===void 0?void 0:J.taskId;if(B===void 0){let q={jsonrpc:"2.0",id:X.id,error:{code:x.MethodNotFound,message:"Method not found"}};if(K&&this._taskMessageQueue)this._enqueueTaskMessage(K,{type:"error",message:q,timestamp:Date.now()},z===null||z===void 0?void 0:z.sessionId).catch((N)=>this._onerror(Error(`Failed to enqueue error response: ${N}`)));else z===null||z===void 0||z.send(q).catch((N)=>this._onerror(Error(`Failed to send an error response: ${N}`)));return}let V=new AbortController;this._requestHandlerAbortControllers.set(X.id,V);let L=(G=X.params)===null||G===void 0?void 0:G.task,U=this._taskStore?this.requestTaskStore(X,z===null||z===void 0?void 0:z.sessionId):void 0,F={signal:V.signal,sessionId:z===null||z===void 0?void 0:z.sessionId,_meta:(H=X.params)===null||H===void 0?void 0:H._meta,sendNotification:async(q)=>{let N={relatedRequestId:X.id};if(K)N.relatedTask={taskId:K};await this.notification(q,N)},sendRequest:async(q,N,w)=>{var M,R;let S={...w,relatedRequestId:X.id};if(K&&!S.relatedTask)S.relatedTask={taskId:K};let C=(R=(M=S.relatedTask)===null||M===void 0?void 0:M.taskId)!==null&&R!==void 0?R:K;if(C&&U)await U.updateTaskStatus(C,"input_required");return await this.request(q,N,S)},authInfo:Q===null||Q===void 0?void 0:Q.authInfo,requestId:X.id,requestInfo:Q===null||Q===void 0?void 0:Q.requestInfo,taskId:K,taskStore:U,taskRequestedTtl:L===null||L===void 0?void 0:L.ttl,closeSSEStream:Q===null||Q===void 0?void 0:Q.closeSSEStream,closeStandaloneSSEStream:Q===null||Q===void 0?void 0:Q.closeStandaloneSSEStream};Promise.resolve().then(()=>{if(L)this.assertTaskHandlerCapability(X.method)}).then(()=>B(X,F)).then(async(q)=>{if(V.signal.aborted)return;let N={result:q,jsonrpc:"2.0",id:X.id};if(K&&this._taskMessageQueue)await this._enqueueTaskMessage(K,{type:"response",message:N,timestamp:Date.now()},z===null||z===void 0?void 0:z.sessionId);else await(z===null||z===void 0?void 0:z.send(N))},async(q)=>{var N;if(V.signal.aborted)return;let w={jsonrpc:"2.0",id:X.id,error:{code:Number.isSafeInteger(q.code)?q.code:x.InternalError,message:(N=q.message)!==null&&N!==void 0?N:"Internal error",...q.data!==void 0&&{data:q.data}}};if(K&&this._taskMessageQueue)await this._enqueueTaskMessage(K,{type:"error",message:w,timestamp:Date.now()},z===null||z===void 0?void 0:z.sessionId);else await(z===null||z===void 0?void 0:z.send(w))}).catch((q)=>this._onerror(Error(`Failed to send response: ${q}`))).finally(()=>{this._requestHandlerAbortControllers.delete(X.id)})}_onprogress(X){let{progressToken:Q,...$}=X.params,Y=Number(Q),W=this._progressHandlers.get(Y);if(!W){this._onerror(Error(`Received a progress notification for an unknown token: ${JSON.stringify(X)}`));return}let J=this._responseHandlers.get(Y),G=this._timeoutInfo.get(Y);if(G&&J&&G.resetTimeoutOnProgress)try{this._resetTimeout(Y)}catch(H){this._responseHandlers.delete(Y),this._progressHandlers.delete(Y),this._cleanupTimeout(Y),J(H);return}W($)}_onresponse(X){let Q=Number(X.id),$=this._requestResolvers.get(Q);if($){if(this._requestResolvers.delete(Q),CX(X))$(X);else{let J=new k(X.error.code,X.error.message,X.error.data);$(J)}return}let Y=this._responseHandlers.get(Q);if(Y===void 0){this._onerror(Error(`Received a response for an unknown message ID: ${JSON.stringify(X)}`));return}this._responseHandlers.delete(Q),this._cleanupTimeout(Q);let W=!1;if(CX(X)&&X.result&&typeof X.result==="object"){let J=X.result;if(J.task&&typeof J.task==="object"){let G=J.task;if(typeof G.taskId==="string")W=!0,this._taskProgressTokens.set(G.taskId,Q)}}if(!W)this._progressHandlers.delete(Q);if(CX(X))Y(X);else{let J=k.fromError(X.error.code,X.error.message,X.error.data);Y(J)}}get transport(){return this._transport}async close(){var X;await((X=this._transport)===null||X===void 0?void 0:X.close())}async*requestStream(X,Q,$){var Y,W,J,G;let{task:H}=$!==null&&$!==void 0?$:{};if(!H){try{yield{type:"result",result:await this.request(X,Q,$)}}catch(z){yield{type:"error",error:z instanceof k?z:new k(x.InternalError,String(z))}}return}let B;try{let z=await this.request(X,_6,$);if(z.task)B=z.task.taskId,yield{type:"taskCreated",task:z.task};else throw new k(x.InternalError,"Task creation did not return a task");while(!0){let K=await this.getTask({taskId:B},$);if(yield{type:"taskStatus",task:K},u1(K.status)){if(K.status==="completed")yield{type:"result",result:await this.getTaskResult({taskId:B},Q,$)};else if(K.status==="failed")yield{type:"error",error:new k(x.InternalError,`Task ${B} failed`)};else if(K.status==="cancelled")yield{type:"error",error:new k(x.InternalError,`Task ${B} was cancelled`)};return}if(K.status==="input_required"){yield{type:"result",result:await this.getTaskResult({taskId:B},Q,$)};return}let V=(J=(Y=K.pollInterval)!==null&&Y!==void 0?Y:(W=this._options)===null||W===void 0?void 0:W.defaultTaskPollInterval)!==null&&J!==void 0?J:1000;await new Promise((L)=>setTimeout(L,V)),(G=$===null||$===void 0?void 0:$.signal)===null||G===void 0||G.throwIfAborted()}}catch(z){yield{type:"error",error:z instanceof k?z:new k(x.InternalError,String(z))}}}request(X,Q,$){let{relatedRequestId:Y,resumptionToken:W,onresumptiontoken:J,task:G,relatedTask:H}=$!==null&&$!==void 0?$:{};return new Promise((B,z)=>{var K,V,L,U,F,q,N;let w=(s)=>{z(s)};if(!this._transport){w(Error("Not connected"));return}if(((K=this._options)===null||K===void 0?void 0:K.enforceStrictCapabilities)===!0)try{if(this.assertCapabilityForMethod(X.method),G)this.assertTaskCapability(X.method)}catch(s){w(s);return}(V=$===null||$===void 0?void 0:$.signal)===null||V===void 0||V.throwIfAborted();let M=this._requestMessageId++,R={...X,jsonrpc:"2.0",id:M};if($===null||$===void 0?void 0:$.onprogress)this._progressHandlers.set(M,$.onprogress),R.params={...X.params,_meta:{...((L=X.params)===null||L===void 0?void 0:L._meta)||{},progressToken:M}};if(G)R.params={...R.params,task:G};if(H)R.params={...R.params,_meta:{...((U=R.params)===null||U===void 0?void 0:U._meta)||{},[z1]:H}};let S=(s)=>{var D0;this._responseHandlers.delete(M),this._progressHandlers.delete(M),this._cleanupTimeout(M),(D0=this._transport)===null||D0===void 0||D0.send({jsonrpc:"2.0",method:"notifications/cancelled",params:{requestId:M,reason:String(s)}},{relatedRequestId:Y,resumptionToken:W,onresumptiontoken:J}).catch((L1)=>this._onerror(Error(`Failed to send cancellation: ${L1}`)));let q0=s instanceof k?s:new k(x.RequestTimeout,String(s));z(q0)};this._responseHandlers.set(M,(s)=>{var D0;if((D0=$===null||$===void 0?void 0:$.signal)===null||D0===void 0?void 0:D0.aborted)return;if(s instanceof Error)return z(s);try{let q0=f1(Q,s.result);if(!q0.success)z(q0.error);else B(q0.data)}catch(q0){z(q0)}}),(F=$===null||$===void 0?void 0:$.signal)===null||F===void 0||F.addEventListener("abort",()=>{var s;S((s=$===null||$===void 0?void 0:$.signal)===null||s===void 0?void 0:s.reason)});let C=(q=$===null||$===void 0?void 0:$.timeout)!==null&&q!==void 0?q:NN,K0=()=>S(k.fromError(x.RequestTimeout,"Request timed out",{timeout:C}));this._setupTimeout(M,C,$===null||$===void 0?void 0:$.maxTotalTimeout,K0,(N=$===null||$===void 0?void 0:$.resetTimeoutOnProgress)!==null&&N!==void 0?N:!1);let U0=H===null||H===void 0?void 0:H.taskId;if(U0){let s=(D0)=>{let q0=this._responseHandlers.get(M);if(q0)q0(D0);else this._onerror(Error(`Response handler missing for side-channeled request ${M}`))};this._requestResolvers.set(M,s),this._enqueueTaskMessage(U0,{type:"request",message:R,timestamp:Date.now()}).catch((D0)=>{this._cleanupTimeout(M),z(D0)})}else this._transport.send(R,{relatedRequestId:Y,resumptionToken:W,onresumptiontoken:J}).catch((s)=>{this._cleanupTimeout(M),z(s)})})}async getTask(X,Q){return this.request({method:"tasks/get",params:X},Q8,Q)}async getTaskResult(X,Q,$){return this.request({method:"tasks/result",params:X},Q,$)}async listTasks(X,Q){return this.request({method:"tasks/list",params:X},W8,Q)}async cancelTask(X,Q){return this.request({method:"tasks/cancel",params:X},q5,Q)}async notification(X,Q){var $,Y,W,J,G;if(!this._transport)throw Error("Not connected");this.assertNotificationCapability(X.method);let H=($=Q===null||Q===void 0?void 0:Q.relatedTask)===null||$===void 0?void 0:$.taskId;if(H){let V={...X,jsonrpc:"2.0",params:{...X.params,_meta:{...((Y=X.params)===null||Y===void 0?void 0:Y._meta)||{},[z1]:Q.relatedTask}}};await this._enqueueTaskMessage(H,{type:"notification",message:V,timestamp:Date.now()});return}if(((J=(W=this._options)===null||W===void 0?void 0:W.debouncedNotificationMethods)!==null&&J!==void 0?J:[]).includes(X.method)&&!X.params&&!(Q===null||Q===void 0?void 0:Q.relatedRequestId)&&!(Q===null||Q===void 0?void 0:Q.relatedTask)){if(this._pendingDebouncedNotifications.has(X.method))return;this._pendingDebouncedNotifications.add(X.method),Promise.resolve().then(()=>{var V,L;if(this._pendingDebouncedNotifications.delete(X.method),!this._transport)return;let U={...X,jsonrpc:"2.0"};if(Q===null||Q===void 0?void 0:Q.relatedTask)U={...U,params:{...U.params,_meta:{...((V=U.params)===null||V===void 0?void 0:V._meta)||{},[z1]:Q.relatedTask}}};(L=this._transport)===null||L===void 0||L.send(U,Q).catch((F)=>this._onerror(F))});return}let K={...X,jsonrpc:"2.0"};if(Q===null||Q===void 0?void 0:Q.relatedTask)K={...K,params:{...K.params,_meta:{...((G=K.params)===null||G===void 0?void 0:G._meta)||{},[z1]:Q.relatedTask}}};await this._transport.send(K,Q)}setRequestHandler(X,Q){let $=r$(X);this.assertRequestHandlerCapability($),this._requestHandlers.set($,(Y,W)=>{let J=o$(X,Y);return Promise.resolve(Q(J,W))})}removeRequestHandler(X){this._requestHandlers.delete(X)}assertCanSetRequestHandler(X){if(this._requestHandlers.has(X))throw Error(`A request handler for ${X} already exists, which would be overridden`)}setNotificationHandler(X,Q){let $=r$(X);this._notificationHandlers.set($,(Y)=>{let W=o$(X,Y);return Promise.resolve(Q(W))})}removeNotificationHandler(X){this._notificationHandlers.delete(X)}_cleanupTaskProgressHandler(X){let Q=this._taskProgressTokens.get(X);if(Q!==void 0)this._progressHandlers.delete(Q),this._taskProgressTokens.delete(X)}async _enqueueTaskMessage(X,Q,$){var Y;if(!this._taskStore||!this._taskMessageQueue)throw Error("Cannot enqueue task message: taskStore and taskMessageQueue are not configured");let W=(Y=this._options)===null||Y===void 0?void 0:Y.maxTaskQueueSize;await this._taskMessageQueue.enqueue(X,Q,$,W)}async _clearTaskQueue(X,Q){if(this._taskMessageQueue){let $=await this._taskMessageQueue.dequeueAll(X,Q);for(let Y of $)if(Y.type==="request"&&Z$(Y.message)){let W=Y.message.id,J=this._requestResolvers.get(W);if(J)J(new k(x.InternalError,"Task cancelled or completed")),this._requestResolvers.delete(W);else this._onerror(Error(`Resolver missing for request ${W} during task ${X} cleanup`))}}}async _waitForTaskUpdate(X,Q){var $,Y,W;let J=(Y=($=this._options)===null||$===void 0?void 0:$.defaultTaskPollInterval)!==null&&Y!==void 0?Y:1000;try{let G=await((W=this._taskStore)===null||W===void 0?void 0:W.getTask(X));if(G===null||G===void 0?void 0:G.pollInterval)J=G.pollInterval}catch(G){}return new Promise((G,H)=>{if(Q.aborted){H(new k(x.InvalidRequest,"Request cancelled"));return}let B=setTimeout(G,J);Q.addEventListener("abort",()=>{clearTimeout(B),H(new k(x.InvalidRequest,"Request cancelled"))},{once:!0})})}requestTaskStore(X,Q){let $=this._taskStore;if(!$)throw Error("No task store configured");return{createTask:async(Y)=>{if(!X)throw Error("No request provided");return await $.createTask(Y,X.id,{method:X.method,params:X.params},Q)},getTask:async(Y)=>{let W=await $.getTask(Y,Q);if(!W)throw new k(x.InvalidParams,"Failed to retrieve task: Task not found");return W},storeTaskResult:async(Y,W,J)=>{await $.storeTaskResult(Y,W,J,Q);let G=await $.getTask(Y,Q);if(G){let H=xX.parse({method:"notifications/tasks/status",params:G});if(await this.notification(H),u1(G.status))this._cleanupTaskProgressHandler(Y)}},getTaskResult:(Y)=>{return $.getTaskResult(Y,Q)},updateTaskStatus:async(Y,W,J)=>{let G=await $.getTask(Y,Q);if(!G)throw new k(x.InvalidParams,`Task "${Y}" not found - it may have been cleaned up`);if(u1(G.status))throw new k(x.InvalidParams,`Cannot update task "${Y}" from terminal status "${G.status}" to "${W}". Terminal states (completed, failed, cancelled) cannot transition to other states.`);await $.updateTaskStatus(Y,W,J,Q);let H=await $.getTask(Y,Q);if(H){let B=xX.parse({method:"notifications/tasks/status",params:H});if(await this.notification(B),u1(H.status))this._cleanupTaskProgressHandler(Y)}},listTasks:(Y)=>{return $.listTasks(Y,Q)}}}}function QG(X){return X!==null&&typeof X==="object"&&!Array.isArray(X)}function $G(X,Q){let $={...X};for(let Y in Q){let W=Y,J=Q[W];if(J===void 0)continue;let G=$[W];if(QG(G)&&QG(J))$[W]={...G,...J};else $[W]=J}return $}var hz=K7(cY(),1),uz=K7(fz(),1);function II(){let X=new hz.Ajv({strict:!1,validateFormats:!0,validateSchema:!1,allErrors:!0});return uz.default(X),X}class eY{constructor(X){this._ajv=X!==null&&X!==void 0?X:II()}getValidator(X){var Q;let $="$id"in X&&typeof X.$id==="string"?(Q=this._ajv.getSchema(X.$id))!==null&&Q!==void 0?Q:this._ajv.compile(X):this._ajv.compile(X);return(Y)=>{if($(Y))return{valid:!0,data:Y,errorMessage:void 0};else return{valid:!1,data:void 0,errorMessage:this._ajv.errorsText($.errors)}}}}class X7{constructor(X){this._server=X}requestStream(X,Q,$){return this._server.requestStream(X,Q,$)}async getTask(X,Q){return this._server.getTask({taskId:X},Q)}async getTaskResult(X,Q,$){return this._server.getTaskResult({taskId:X},Q,$)}async listTasks(X,Q){return this._server.listTasks(X?{cursor:X}:void 0,Q)}async cancelTask(X,Q){return this._server.cancelTask({taskId:X},Q)}}function lz(X,Q,$){var Y;if(!X)throw Error(`${$} does not support task creation (required for ${Q})`);switch(Q){case"tools/call":if(!((Y=X.tools)===null||Y===void 0?void 0:Y.call))throw Error(`${$} does not support task creation for tools/call (required for ${Q})`);break;default:break}}function mz(X,Q,$){var Y,W;if(!X)throw Error(`${$} does not support task creation (required for ${Q})`);switch(Q){case"sampling/createMessage":if(!((Y=X.sampling)===null||Y===void 0?void 0:Y.createMessage))throw Error(`${$} does not support task creation for sampling/createMessage (required for ${Q})`);break;case"elicitation/create":if(!((W=X.elicitation)===null||W===void 0?void 0:W.create))throw Error(`${$} does not support task creation for elicitation/create (required for ${Q})`);break;default:break}}class Q7 extends t${constructor(X,Q){var $,Y;super(Q);if(this._serverInfo=X,this._loggingLevels=new Map,this.LOG_LEVEL_SEVERITY=new Map(yX.options.map((W,J)=>[W,J])),this.isMessageIgnored=(W,J)=>{let G=this._loggingLevels.get(J);return G?this.LOG_LEVEL_SEVERITY.get(W)<this.LOG_LEVEL_SEVERITY.get(G):!1},this._capabilities=($=Q===null||Q===void 0?void 0:Q.capabilities)!==null&&$!==void 0?$:{},this._instructions=Q===null||Q===void 0?void 0:Q.instructions,this._jsonSchemaValidator=(Y=Q===null||Q===void 0?void 0:Q.jsonSchemaValidator)!==null&&Y!==void 0?Y:new eY,this.setRequestHandler(C$,(W)=>this._oninitialize(W)),this.setNotificationHandler(k$,()=>{var W;return(W=this.oninitialized)===null||W===void 0?void 0:W.call(this)}),this._capabilities.logging)this.setRequestHandler(f$,async(W,J)=>{var G;let H=J.sessionId||((G=J.requestInfo)===null||G===void 0?void 0:G.headers["mcp-session-id"])||void 0,{level:B}=W.params,z=yX.safeParse(B);if(z.success)this._loggingLevels.set(H,z.data);return{}})}get experimental(){if(!this._experimental)this._experimental={tasks:new X7(this)};return this._experimental}registerCapabilities(X){if(this.transport)throw Error("Cannot register capabilities after connecting to transport");this._capabilities=$G(this._capabilities,X)}setRequestHandler(X,Q){var $,Y,W;let J=h1(X),G=J===null||J===void 0?void 0:J.method;if(!G)throw Error("Schema is missing a method literal");let H;if(m0(G)){let z=G,K=($=z._zod)===null||$===void 0?void 0:$.def;H=(Y=K===null||K===void 0?void 0:K.value)!==null&&Y!==void 0?Y:z.value}else{let z=G,K=z._def;H=(W=K===null||K===void 0?void 0:K.value)!==null&&W!==void 0?W:z.value}if(typeof H!=="string")throw Error("Schema method literal must be a string");if(H==="tools/call"){let z=async(K,V)=>{let L=f1(y6,K);if(!L.success){let N=L.error instanceof Error?L.error.message:String(L.error);throw new k(x.InvalidParams,`Invalid tools/call request: ${N}`)}let{params:U}=L.data,F=await Promise.resolve(Q(K,V));if(U.task){let N=f1(_6,F);if(!N.success){let w=N.error instanceof Error?N.error.message:String(N.error);throw new k(x.InvalidParams,`Invalid task creation result: ${w}`)}return N.data}let q=f1(U8,F);if(!q.success){let N=q.error instanceof Error?q.error.message:String(q.error);throw new k(x.InvalidParams,`Invalid tools/call result: ${N}`)}return q.data};return super.setRequestHandler(X,z)}return super.setRequestHandler(X,Q)}assertCapabilityForMethod(X){var Q,$,Y;switch(X){case"sampling/createMessage":if(!((Q=this._clientCapabilities)===null||Q===void 0?void 0:Q.sampling))throw Error(`Client does not support sampling (required for ${X})`);break;case"elicitation/create":if(!(($=this._clientCapabilities)===null||$===void 0?void 0:$.elicitation))throw Error(`Client does not support elicitation (required for ${X})`);break;case"roots/list":if(!((Y=this._clientCapabilities)===null||Y===void 0?void 0:Y.roots))throw Error(`Client does not support listing roots (required for ${X})`);break;case"ping":break}}assertNotificationCapability(X){var Q,$;switch(X){case"notifications/message":if(!this._capabilities.logging)throw Error(`Server does not support logging (required for ${X})`);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 ${X})`);break;case"notifications/tools/list_changed":if(!this._capabilities.tools)throw Error(`Server does not support notifying of tool list changes (required for ${X})`);break;case"notifications/prompts/list_changed":if(!this._capabilities.prompts)throw Error(`Server does not support notifying of prompt list changes (required for ${X})`);break;case"notifications/elicitation/complete":if(!(($=(Q=this._clientCapabilities)===null||Q===void 0?void 0:Q.elicitation)===null||$===void 0?void 0:$.url))throw Error(`Client does not support URL elicitation (required for ${X})`);break;case"notifications/cancelled":break;case"notifications/progress":break}}assertRequestHandlerCapability(X){if(!this._capabilities)return;switch(X){case"completion/complete":if(!this._capabilities.completions)throw Error(`Server does not support completions (required for ${X})`);break;case"logging/setLevel":if(!this._capabilities.logging)throw Error(`Server does not support logging (required for ${X})`);break;case"prompts/get":case"prompts/list":if(!this._capabilities.prompts)throw Error(`Server does not support prompts (required for ${X})`);break;case"resources/list":case"resources/templates/list":case"resources/read":if(!this._capabilities.resources)throw Error(`Server does not support resources (required for ${X})`);break;case"tools/call":case"tools/list":if(!this._capabilities.tools)throw Error(`Server does not support tools (required for ${X})`);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 ${X})`);break;case"ping":case"initialize":break}}assertTaskCapability(X){var Q,$;mz(($=(Q=this._clientCapabilities)===null||Q===void 0?void 0:Q.tasks)===null||$===void 0?void 0:$.requests,X,"Client")}assertTaskHandlerCapability(X){var Q;if(!this._capabilities)return;lz((Q=this._capabilities.tasks)===null||Q===void 0?void 0:Q.requests,X,"Server")}async _oninitialize(X){let Q=X.params.protocolVersion;return this._clientCapabilities=X.params.capabilities,this._clientVersion=X.params.clientInfo,{protocolVersion:Y5.includes(Q)?Q:P$,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"},t4)}async createMessage(X,Q){var $,Y;if(X.tools||X.toolChoice){if(!((Y=($=this._clientCapabilities)===null||$===void 0?void 0:$.sampling)===null||Y===void 0?void 0:Y.tools))throw Error("Client does not support sampling tools capability.")}if(X.messages.length>0){let W=X.messages[X.messages.length-1],J=Array.isArray(W.content)?W.content:[W.content],G=J.some((K)=>K.type==="tool_result"),H=X.messages.length>1?X.messages[X.messages.length-2]:void 0,B=H?Array.isArray(H.content)?H.content:[H.content]:[],z=B.some((K)=>K.type==="tool_use");if(G){if(J.some((K)=>K.type!=="tool_result"))throw Error("The last message must contain only tool_result content if any is present");if(!z)throw Error("tool_result blocks are not matching any tool_use from the previous message")}if(z){let K=new Set(B.filter((L)=>L.type==="tool_use").map((L)=>L.id)),V=new Set(J.filter((L)=>L.type==="tool_result").map((L)=>L.toolUseId));if(K.size!==V.size||![...K].every((L)=>V.has(L)))throw Error("ids of tool_result blocks and tool_use blocks from previous message do not match")}}if(X.tools)return this.request({method:"sampling/createMessage",params:X},u$,Q);return this.request({method:"sampling/createMessage",params:X},h$,Q)}async elicitInput(X,Q){var $,Y,W,J,G;switch(($=X.mode)!==null&&$!==void 0?$:"form"){case"url":{if(!((W=(Y=this._clientCapabilities)===null||Y===void 0?void 0:Y.elicitation)===null||W===void 0?void 0:W.url))throw Error("Client does not support url elicitation.");let B=X;return this.request({method:"elicitation/create",params:B},V8,Q)}case"form":{if(!((G=(J=this._clientCapabilities)===null||J===void 0?void 0:J.elicitation)===null||G===void 0?void 0:G.form))throw Error("Client does not support form elicitation.");let B=X.mode==="form"?X:{...X,mode:"form"},z=await this.request({method:"elicitation/create",params:B},V8,Q);if(z.action==="accept"&&z.content&&B.requestedSchema)try{let V=this._jsonSchemaValidator.getValidator(B.requestedSchema)(z.content);if(!V.valid)throw new k(x.InvalidParams,`Elicitation response content does not match requested schema: ${V.errorMessage}`)}catch(K){if(K instanceof k)throw K;throw new k(x.InternalError,`Error validating elicitation response: ${K instanceof Error?K.message:String(K)}`)}return z}}}createElicitationCompletionNotifier(X,Q){var $,Y;if(!((Y=($=this._clientCapabilities)===null||$===void 0?void 0:$.elicitation)===null||Y===void 0?void 0:Y.url))throw Error("Client does not support URL elicitation (required for notifications/elicitation/complete)");return()=>this.notification({method:"notifications/elicitation/complete",params:{elicitationId:X}},Q)}async listRoots(X,Q){return this.request({method:"roots/list",params:X},l$,Q)}async sendLoggingMessage(X,Q){if(this._capabilities.logging){if(!this.isMessageIgnored(X.level,Q))return this.notification({method:"notifications/message",params:X})}}async sendResourceUpdated(X){return this.notification({method:"notifications/resources/updated",params:X})}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 pz=Symbol.for("mcp.completable");function dz(X){return!!X&&typeof X==="object"&&pz in X}function iz(X){let Q=X[pz];return Q===null||Q===void 0?void 0:Q.complete}var cz;(function(X){X.Completable="McpCompletable"})(cz||(cz={}));var EI=/^[A-Za-z0-9._-]{1,128}$/;function bI(X){let Q=[];if(X.length===0)return{isValid:!1,warnings:["Tool name cannot be empty"]};if(X.length>128)return{isValid:!1,warnings:[`Tool name exceeds maximum length of 128 characters (current: ${X.length})`]};if(X.includes(" "))Q.push("Tool name contains spaces, which may cause parsing issues");if(X.includes(","))Q.push("Tool name contains commas, which may cause parsing issues");if(X.startsWith("-")||X.endsWith("-"))Q.push("Tool name starts or ends with a dash, which may cause parsing issues in some contexts");if(X.startsWith(".")||X.endsWith("."))Q.push("Tool name starts or ends with a dot, which may cause parsing issues in some contexts");if(!EI.test(X)){let $=X.split("").filter((Y)=>!/[A-Za-z0-9._-]/.test(Y)).filter((Y,W,J)=>J.indexOf(Y)===W);return Q.push(`Tool name contains invalid characters: ${$.map((Y)=>`"${Y}"`).join(", ")}`,"Allowed characters are: A-Z, a-z, 0-9, underscore (_), dash (-), and dot (.)"),{isValid:!1,warnings:Q}}return{isValid:!0,warnings:Q}}function PI(X,Q){if(Q.length>0){console.warn(`Tool name validation warning for "${X}":`);for(let $ of Q)console.warn(` - ${$}`);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 $7(X){let Q=bI(X);return PI(X,Q.warnings),Q.isValid}class Y7{constructor(X){this._mcpServer=X}registerToolTask(X,Q,$){let Y={taskSupport:"required",...Q.execution};if(Y.taskSupport==="forbidden")throw Error(`Cannot register task-based tool '${X}' with taskSupport 'forbidden'. Use registerTool() instead.`);return this._mcpServer._createRegisteredTool(X,Q.title,Q.description,Q.inputSchema,Q.outputSchema,Q.annotations,Y,Q._meta,$)}}class J7{constructor(X,Q){this._registeredResources={},this._registeredResourceTemplates={},this._registeredTools={},this._registeredPrompts={},this._toolHandlersInitialized=!1,this._completionHandlerInitialized=!1,this._resourceHandlersInitialized=!1,this._promptHandlersInitialized=!1,this.server=new Q7(X,Q)}get experimental(){if(!this._experimental)this._experimental={tasks:new Y7(this)};return this._experimental}async connect(X){return await this.server.connect(X)}async close(){await this.server.close()}setToolRequestHandlers(){if(this._toolHandlersInitialized)return;this.server.assertCanSetRequestHandler(r1(K8)),this.server.assertCanSetRequestHandler(r1(y6)),this.server.registerCapabilities({tools:{listChanged:!0}}),this.server.setRequestHandler(K8,()=>({tools:Object.entries(this._registeredTools).filter(([,X])=>X.enabled).map(([X,Q])=>{let $={name:X,title:Q.title,description:Q.description,inputSchema:(()=>{let Y=v6(Q.inputSchema);return Y?n$(Y,{strictUnions:!0,pipeStrategy:"input"}):SI})(),annotations:Q.annotations,execution:Q.execution,_meta:Q._meta};if(Q.outputSchema){let Y=v6(Q.outputSchema);if(Y)$.outputSchema=n$(Y,{strictUnions:!0,pipeStrategy:"output"})}return $})})),this.server.setRequestHandler(y6,async(X,Q)=>{var $;try{let Y=this._registeredTools[X.params.name];if(!Y)throw new k(x.InvalidParams,`Tool ${X.params.name} not found`);if(!Y.enabled)throw new k(x.InvalidParams,`Tool ${X.params.name} disabled`);let W=!!X.params.task,J=($=Y.execution)===null||$===void 0?void 0:$.taskSupport,G="createTask"in Y.handler;if((J==="required"||J==="optional")&&!G)throw new k(x.InternalError,`Tool ${X.params.name} has taskSupport '${J}' but was not registered with registerToolTask`);if(J==="required"&&!W)throw new k(x.MethodNotFound,`Tool ${X.params.name} requires task augmentation (taskSupport: 'required')`);if(J==="optional"&&!W&&G)return await this.handleAutomaticTaskPolling(Y,X,Q);let H=await this.validateToolInput(Y,X.params.arguments,X.params.name),B=await this.executeToolHandler(Y,H,Q);if(W)return B;return await this.validateToolOutput(Y,B,X.params.name),B}catch(Y){if(Y instanceof k){if(Y.code===x.UrlElicitationRequired)throw Y}return this.createToolError(Y instanceof Error?Y.message:String(Y))}}),this._toolHandlersInitialized=!0}createToolError(X){return{content:[{type:"text",text:X}],isError:!0}}async validateToolInput(X,Q,$){if(!X.inputSchema)return;let Y=v6(X.inputSchema),W=Y!==null&&Y!==void 0?Y:X.inputSchema,J=await m4(W,Q);if(!J.success){let G="error"in J?J.error:"Unknown error",H=c4(G);throw new k(x.InvalidParams,`Input validation error: Invalid arguments for tool ${$}: ${H}`)}return J.data}async validateToolOutput(X,Q,$){if(!X.outputSchema)return;if(!("content"in Q))return;if(Q.isError)return;if(!Q.structuredContent)throw new k(x.InvalidParams,`Output validation error: Tool ${$} has an output schema but no structured content was provided`);let Y=v6(X.outputSchema),W=await m4(Y,Q.structuredContent);if(!W.success){let J="error"in W?W.error:"Unknown error",G=c4(J);throw new k(x.InvalidParams,`Output validation error: Invalid structured content for tool ${$}: ${G}`)}}async executeToolHandler(X,Q,$){let Y=X.handler;if("createTask"in Y){if(!$.taskStore)throw Error("No task store provided.");let J={...$,taskStore:$.taskStore};if(X.inputSchema)return await Promise.resolve(Y.createTask(Q,J));else return await Promise.resolve(Y.createTask(J))}if(X.inputSchema)return await Promise.resolve(Y(Q,$));else return await Promise.resolve(Y($))}async handleAutomaticTaskPolling(X,Q,$){var Y;if(!$.taskStore)throw Error("No task store provided for task-capable tool.");let W=await this.validateToolInput(X,Q.params.arguments,Q.params.name),J=X.handler,G={...$,taskStore:$.taskStore},H=W?await Promise.resolve(J.createTask(W,G)):await Promise.resolve(J.createTask(G)),B=H.task.taskId,z=H.task,K=(Y=z.pollInterval)!==null&&Y!==void 0?Y:5000;while(z.status!=="completed"&&z.status!=="failed"&&z.status!=="cancelled"){await new Promise((L)=>setTimeout(L,K));let V=await $.taskStore.getTask(B);if(!V)throw new k(x.InternalError,`Task ${B} not found during polling`);z=V}return await $.taskStore.getTaskResult(B)}setCompletionRequestHandler(){if(this._completionHandlerInitialized)return;this.server.assertCanSetRequestHandler(r1(L8)),this.server.registerCapabilities({completions:{}}),this.server.setRequestHandler(L8,async(X)=>{switch(X.params.ref.type){case"ref/prompt":return A5(X),this.handlePromptCompletion(X,X.params.ref);case"ref/resource":return M5(X),this.handleResourceCompletion(X,X.params.ref);default:throw new k(x.InvalidParams,`Invalid completion reference: ${X.params.ref}`)}}),this._completionHandlerInitialized=!0}async handlePromptCompletion(X,Q){let $=this._registeredPrompts[Q.name];if(!$)throw new k(x.InvalidParams,`Prompt ${Q.name} not found`);if(!$.enabled)throw new k(x.InvalidParams,`Prompt ${Q.name} disabled`);if(!$.argsSchema)return H4;let Y=h1($.argsSchema),W=Y===null||Y===void 0?void 0:Y[X.params.argument.name];if(!dz(W))return H4;let J=iz(W);if(!J)return H4;let G=await J(X.params.argument.value,X.params.context);return rz(G)}async handleResourceCompletion(X,Q){let $=Object.values(this._registeredResourceTemplates).find((J)=>J.resourceTemplate.uriTemplate.toString()===Q.uri);if(!$){if(this._registeredResources[Q.uri])return H4;throw new k(x.InvalidParams,`Resource template ${X.params.ref.uri} not found`)}let Y=$.resourceTemplate.completeCallback(X.params.argument.name);if(!Y)return H4;let W=await Y(X.params.argument.value,X.params.context);return rz(W)}setResourceRequestHandlers(){if(this._resourceHandlersInitialized)return;this.server.assertCanSetRequestHandler(r1(J8)),this.server.assertCanSetRequestHandler(r1(G8)),this.server.assertCanSetRequestHandler(r1(H8)),this.server.registerCapabilities({resources:{listChanged:!0}}),this.server.setRequestHandler(J8,async(X,Q)=>{let $=Object.entries(this._registeredResources).filter(([W,J])=>J.enabled).map(([W,J])=>({uri:W,name:J.name,...J.metadata})),Y=[];for(let W of Object.values(this._registeredResourceTemplates)){if(!W.resourceTemplate.listCallback)continue;let J=await W.resourceTemplate.listCallback(Q);for(let G of J.resources)Y.push({...W.metadata,...G})}return{resources:[...$,...Y]}}),this.server.setRequestHandler(G8,async()=>{return{resourceTemplates:Object.entries(this._registeredResourceTemplates).map(([Q,$])=>({name:Q,uriTemplate:$.resourceTemplate.uriTemplate.toString(),...$.metadata}))}}),this.server.setRequestHandler(H8,async(X,Q)=>{let $=new URL(X.params.uri),Y=this._registeredResources[$.toString()];if(Y){if(!Y.enabled)throw new k(x.InvalidParams,`Resource ${$} disabled`);return Y.readCallback($,Q)}for(let W of Object.values(this._registeredResourceTemplates)){let J=W.resourceTemplate.uriTemplate.match($.toString());if(J)return W.readCallback($,J,Q)}throw new k(x.InvalidParams,`Resource ${$} not found`)}),this.setCompletionRequestHandler(),this._resourceHandlersInitialized=!0}setPromptRequestHandlers(){if(this._promptHandlersInitialized)return;this.server.assertCanSetRequestHandler(r1(B8)),this.server.assertCanSetRequestHandler(r1(z8)),this.server.registerCapabilities({prompts:{listChanged:!0}}),this.server.setRequestHandler(B8,()=>({prompts:Object.entries(this._registeredPrompts).filter(([,X])=>X.enabled).map(([X,Q])=>{return{name:X,title:Q.title,description:Q.description,arguments:Q.argsSchema?CI(Q.argsSchema):void 0}})})),this.server.setRequestHandler(z8,async(X,Q)=>{let $=this._registeredPrompts[X.params.name];if(!$)throw new k(x.InvalidParams,`Prompt ${X.params.name} not found`);if(!$.enabled)throw new k(x.InvalidParams,`Prompt ${X.params.name} disabled`);if($.argsSchema){let Y=v6($.argsSchema),W=await m4(Y,X.params.arguments);if(!W.success){let H="error"in W?W.error:"Unknown error",B=c4(H);throw new k(x.InvalidParams,`Invalid arguments for prompt ${X.params.name}: ${B}`)}let J=W.data,G=$.callback;return await Promise.resolve(G(J,Q))}else{let Y=$.callback;return await Promise.resolve(Y(Q))}}),this.setCompletionRequestHandler(),this._promptHandlersInitialized=!0}resource(X,Q,...$){let Y;if(typeof $[0]==="object")Y=$.shift();let W=$[0];if(typeof Q==="string"){if(this._registeredResources[Q])throw Error(`Resource ${Q} is already registered`);let J=this._createRegisteredResource(X,void 0,Q,Y,W);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),J}else{if(this._registeredResourceTemplates[X])throw Error(`Resource template ${X} is already registered`);let J=this._createRegisteredResourceTemplate(X,void 0,Q,Y,W);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),J}}registerResource(X,Q,$,Y){if(typeof Q==="string"){if(this._registeredResources[Q])throw Error(`Resource ${Q} is already registered`);let W=this._createRegisteredResource(X,$.title,Q,$,Y);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),W}else{if(this._registeredResourceTemplates[X])throw Error(`Resource template ${X} is already registered`);let W=this._createRegisteredResourceTemplate(X,$.title,Q,$,Y);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),W}}_createRegisteredResource(X,Q,$,Y,W){let J={name:X,title:Q,metadata:Y,readCallback:W,enabled:!0,disable:()=>J.update({enabled:!1}),enable:()=>J.update({enabled:!0}),remove:()=>J.update({uri:null}),update:(G)=>{if(typeof G.uri<"u"&&G.uri!==$){if(delete this._registeredResources[$],G.uri)this._registeredResources[G.uri]=J}if(typeof G.name<"u")J.name=G.name;if(typeof G.title<"u")J.title=G.title;if(typeof G.metadata<"u")J.metadata=G.metadata;if(typeof G.callback<"u")J.readCallback=G.callback;if(typeof G.enabled<"u")J.enabled=G.enabled;this.sendResourceListChanged()}};return this._registeredResources[$]=J,J}_createRegisteredResourceTemplate(X,Q,$,Y,W){let J={resourceTemplate:$,title:Q,metadata:Y,readCallback:W,enabled:!0,disable:()=>J.update({enabled:!1}),enable:()=>J.update({enabled:!0}),remove:()=>J.update({name:null}),update:(G)=>{if(typeof G.name<"u"&&G.name!==X){if(delete this._registeredResourceTemplates[X],G.name)this._registeredResourceTemplates[G.name]=J}if(typeof G.title<"u")J.title=G.title;if(typeof G.template<"u")J.resourceTemplate=G.template;if(typeof G.metadata<"u")J.metadata=G.metadata;if(typeof G.callback<"u")J.readCallback=G.callback;if(typeof G.enabled<"u")J.enabled=G.enabled;this.sendResourceListChanged()}};return this._registeredResourceTemplates[X]=J,J}_createRegisteredPrompt(X,Q,$,Y,W){let J={title:Q,description:$,argsSchema:Y===void 0?void 0:k6(Y),callback:W,enabled:!0,disable:()=>J.update({enabled:!1}),enable:()=>J.update({enabled:!0}),remove:()=>J.update({name:null}),update:(G)=>{if(typeof G.name<"u"&&G.name!==X){if(delete this._registeredPrompts[X],G.name)this._registeredPrompts[G.name]=J}if(typeof G.title<"u")J.title=G.title;if(typeof G.description<"u")J.description=G.description;if(typeof G.argsSchema<"u")J.argsSchema=k6(G.argsSchema);if(typeof G.callback<"u")J.callback=G.callback;if(typeof G.enabled<"u")J.enabled=G.enabled;this.sendPromptListChanged()}};return this._registeredPrompts[X]=J,J}_createRegisteredTool(X,Q,$,Y,W,J,G,H,B){$7(X);let z={title:Q,description:$,inputSchema:nz(Y),outputSchema:nz(W),annotations:J,execution:G,_meta:H,handler:B,enabled:!0,disable:()=>z.update({enabled:!1}),enable:()=>z.update({enabled:!0}),remove:()=>z.update({name:null}),update:(K)=>{if(typeof K.name<"u"&&K.name!==X){if(typeof K.name==="string")$7(K.name);if(delete this._registeredTools[X],K.name)this._registeredTools[K.name]=z}if(typeof K.title<"u")z.title=K.title;if(typeof K.description<"u")z.description=K.description;if(typeof K.paramsSchema<"u")z.inputSchema=k6(K.paramsSchema);if(typeof K.callback<"u")z.handler=K.callback;if(typeof K.annotations<"u")z.annotations=K.annotations;if(typeof K._meta<"u")z._meta=K._meta;if(typeof K.enabled<"u")z.enabled=K.enabled;this.sendToolListChanged()}};return this._registeredTools[X]=z,this.setToolRequestHandlers(),this.sendToolListChanged(),z}tool(X,...Q){if(this._registeredTools[X])throw Error(`Tool ${X} is already registered`);let $,Y,W,J;if(typeof Q[0]==="string")$=Q.shift();if(Q.length>1){let H=Q[0];if(W7(H)){if(Y=Q.shift(),Q.length>1&&typeof Q[0]==="object"&&Q[0]!==null&&!W7(Q[0]))J=Q.shift()}else if(typeof H==="object"&&H!==null)J=Q.shift()}let G=Q[0];return this._createRegisteredTool(X,void 0,$,Y,W,J,{taskSupport:"forbidden"},void 0,G)}registerTool(X,Q,$){if(this._registeredTools[X])throw Error(`Tool ${X} is already registered`);let{title:Y,description:W,inputSchema:J,outputSchema:G,annotations:H,_meta:B}=Q;return this._createRegisteredTool(X,Y,W,J,G,H,{taskSupport:"forbidden"},B,$)}prompt(X,...Q){if(this._registeredPrompts[X])throw Error(`Prompt ${X} is already registered`);let $;if(typeof Q[0]==="string")$=Q.shift();let Y;if(Q.length>1)Y=Q.shift();let W=Q[0],J=this._createRegisteredPrompt(X,void 0,$,Y,W);return this.setPromptRequestHandlers(),this.sendPromptListChanged(),J}registerPrompt(X,Q,$){if(this._registeredPrompts[X])throw Error(`Prompt ${X} is already registered`);let{title:Y,description:W,argsSchema:J}=Q,G=this._createRegisteredPrompt(X,Y,W,J,$);return this.setPromptRequestHandlers(),this.sendPromptListChanged(),G}isConnected(){return this.server.transport!==void 0}async sendLoggingMessage(X,Q){return this.server.sendLoggingMessage(X,Q)}sendResourceListChanged(){if(this.isConnected())this.server.sendResourceListChanged()}sendToolListChanged(){if(this.isConnected())this.server.sendToolListChanged()}sendPromptListChanged(){if(this.isConnected())this.server.sendPromptListChanged()}}var SI={type:"object",properties:{}};function oz(X){return X!==null&&typeof X==="object"&&"parse"in X&&typeof X.parse==="function"&&"safeParse"in X&&typeof X.safeParse==="function"}function ZI(X){return"_def"in X||"_zod"in X||oz(X)}function W7(X){if(typeof X!=="object"||X===null)return!1;if(ZI(X))return!1;if(Object.keys(X).length===0)return!0;return Object.values(X).some(oz)}function nz(X){if(!X)return;if(W7(X))return k6(X);return X}function CI(X){let Q=h1(X);if(!Q)return[];return Object.entries(Q).map(([$,Y])=>{let W=_J(Y),J=xJ(Y);return{name:$,description:W,required:!J}})}function r1(X){let Q=h1(X),$=Q===null||Q===void 0?void 0:Q.method;if(!$)throw Error("Schema is missing a method literal");let Y=p4($);if(typeof Y==="string")return Y;throw Error("Schema method literal must be a string")}function rz(X){return{completion:{values:X.slice(0,100),total:X.length,hasMore:X.length>100}}}var H4={completion:{values:[],hasMore:!1}};function kI(X,Q,$,Y,W){return{name:X,description:Q,inputSchema:$,handler:Y,annotations:W?.annotations}}function vI(X){let Q=new J7({name:X.name,version:X.version??"1.0.0"},{capabilities:{tools:X.tools?{}:void 0}});if(X.tools)X.tools.forEach(($)=>{Q.registerTool($.name,{description:$.description,inputSchema:$.inputSchema,annotations:$.annotations},$.handler)});return{type:"sdk",name:X.name,instance:Q}}function s_({prompt:X,options:Q}){let{systemPrompt:$,settingSources:Y,sandbox:W,...J}=Q??{},G,H;if($===void 0)G="";else if(typeof $==="string")G=$;else if($.type==="preset")H=$.append;let B=J.pathToClaudeCodeExecutable;if(!B){let L6=TI(import.meta.url),q6=tz(L6,"..");B=tz(q6,"cli.js")}process.env.CLAUDE_AGENT_SDK_VERSION="0.2.34";let{abortController:z=F6(),additionalDirectories:K=[],agent:V,agents:L,allowedTools:U=[],betas:F,canUseTool:q,continue:N,cwd:w,debug:M,debugFile:R,disallowedTools:S=[],tools:C,env:K0,executable:U0=M6()?"bun":"node",executableArgs:s=[],extraArgs:D0={},fallbackModel:q0,enableFileCheckpointing:L1,forkSession:P1,hooks:o1,includePartialMessages:c,persistSession:Q9,maxThinkingTokens:r6,maxTurns:o6,maxBudgetUsd:t6,mcpServers:a6,model:B4,outputFormat:E0,permissionMode:S1="default",allowDangerouslySkipPermissions:s6=!1,permissionPromptToolName:az,plugins:sz,resume:ez,resumeSessionAt:XK,sessionId:QK,stderr:$K,strictMcpConfig:YK}=J,G7=E0?.type==="json_schema"?E0.schema:void 0,V6=K0;if(!V6)V6={...process.env};if(!V6.CLAUDE_CODE_ENTRYPOINT)V6.CLAUDE_CODE_ENTRYPOINT="sdk-ts";if(L1)V6.CLAUDE_CODE_ENABLE_SDK_FILE_CHECKPOINTING="true";if(!B)throw Error("pathToClaudeCodeExecutable is required");let $9={},H7=new Map;if(a6)for(let[L6,q6]of Object.entries(a6))if(q6.type==="sdk"&&"instance"in q6)H7.set(L6,q6.instance),$9[L6]={type:"sdk",name:L6};else $9[L6]=q6;let WK=typeof X==="string",B7=new XX({abortController:z,additionalDirectories:K,agent:V,betas:F,cwd:w,debug:M,debugFile:R,executable:U0,executableArgs:s,extraArgs:D0,pathToClaudeCodeExecutable:B,env:V6,forkSession:P1,stderr:$K,maxThinkingTokens:r6,maxTurns:o6,maxBudgetUsd:t6,model:B4,fallbackModel:q0,jsonSchema:G7,permissionMode:S1,allowDangerouslySkipPermissions:s6,permissionPromptToolName:az,continueConversation:N,resume:ez,resumeSessionAt:XK,sessionId:QK,settingSources:Y??[],allowedTools:U,disallowedTools:S,tools:C,mcpServers:$9,strictMcpConfig:YK,canUseTool:!!q,hooks:!!o1,includePartialMessages:c,persistSession:Q9,plugins:sz,sandbox:W,spawnClaudeCodeProcess:J.spawnClaudeCodeProcess}),z7=new $X(B7,WK,q,o1,z,H7,G7,{systemPrompt:G,appendSystemPrompt:H,agents:L});if(typeof X==="string")B7.write(Z0({type:"user",session_id:"",message:{role:"user",content:[{type:"text",text:X}]},parent_tool_use_id:null})+`
|
|
55
|
+
]`;continue}if(W+=Y[B],Y[B]==="\\")J=!0;else if(G&&Y[B]==="]")G=!1;else if(!G&&Y[B]==="[")G=!0}try{new RegExp(W)}catch{return console.warn(`Could not convert regex pattern at ${Q.currentPath.join("/")} to a flag-independent form! Falling back to the flag-ignorant source`),X.source}return W}function O8(X,Q){if(Q.target==="openAi")console.warn("Warning: OpenAI may not support records in schemas! Try an array of key-value pairs instead.");if(Q.target==="openApi3"&&X.keyType?._def.typeName===j.ZodEnum)return{type:"object",required:X.keyType._def.values,properties:X.keyType._def.values.reduce((Y,W)=>({...Y,[W]:f(X.valueType._def,{...Q,currentPath:[...Q.currentPath,"properties",W]})??B0(Q)}),{}),additionalProperties:Q.rejectedAdditionalProperties};let $={type:"object",additionalProperties:f(X.valueType._def,{...Q,currentPath:[...Q.currentPath,"additionalProperties"]})??Q.allowedAdditionalProperties};if(Q.target==="openApi3")return $;if(X.keyType?._def.typeName===j.ZodString&&X.keyType._def.checks?.length){let{type:Y,...W}=N8(X.keyType._def,Q);return{...$,propertyNames:W}}else if(X.keyType?._def.typeName===j.ZodEnum)return{...$,propertyNames:{enum:X.keyType._def.values}};else if(X.keyType?._def.typeName===j.ZodBranded&&X.keyType._def.type._def.typeName===j.ZodString&&X.keyType._def.type._def.checks?.length){let{type:Y,...W}=F8(X.keyType._def,Q);return{...$,propertyNames:W}}return $}function g5(X,Q){if(Q.mapStrategy==="record")return O8(X,Q);let $=f(X.keyType._def,{...Q,currentPath:[...Q.currentPath,"items","items","0"]})||B0(Q),Y=f(X.valueType._def,{...Q,currentPath:[...Q.currentPath,"items","items","1"]})||B0(Q);return{type:"array",maxItems:125,items:{type:"array",items:[$,Y],minItems:2,maxItems:2}}}function f5(X){let Q=X.values,Y=Object.keys(X.values).filter((J)=>{return typeof Q[Q[J]]!=="number"}).map((J)=>Q[J]),W=Array.from(new Set(Y.map((J)=>typeof J)));return{type:W.length===1?W[0]==="string"?"string":"number":["string","number"],enum:Y}}function h5(X){return X.target==="openAi"?void 0:{not:B0({...X,currentPath:[...X.currentPath,"not"]})}}function u5(X){return X.target==="openApi3"?{enum:["null"],nullable:!0}:{type:"null"}}var gX={ZodString:"string",ZodNumber:"number",ZodBigInt:"integer",ZodBoolean:"boolean",ZodNull:"null"};function m5(X,Q){if(Q.target==="openApi3")return l5(X,Q);let $=X.options instanceof Map?Array.from(X.options.values()):X.options;if($.every((Y)=>(Y._def.typeName in gX)&&(!Y._def.checks||!Y._def.checks.length))){let Y=$.reduce((W,J)=>{let G=gX[J._def.typeName];return G&&!W.includes(G)?[...W,G]:W},[]);return{type:Y.length>1?Y:Y[0]}}else if($.every((Y)=>Y._def.typeName==="ZodLiteral"&&!Y.description)){let Y=$.reduce((W,J)=>{let G=typeof J._def.value;switch(G){case"string":case"number":case"boolean":return[...W,G];case"bigint":return[...W,"integer"];case"object":if(J._def.value===null)return[...W,"null"];case"symbol":case"undefined":case"function":default:return W}},[]);if(Y.length===$.length){let W=Y.filter((J,G,H)=>H.indexOf(J)===G);return{type:W.length>1?W:W[0],enum:$.reduce((J,G)=>{return J.includes(G._def.value)?J:[...J,G._def.value]},[])}}}else if($.every((Y)=>Y._def.typeName==="ZodEnum"))return{type:"string",enum:$.reduce((Y,W)=>[...Y,...W._def.values.filter((J)=>!Y.includes(J))],[])};return l5(X,Q)}var l5=(X,Q)=>{let $=(X.options instanceof Map?Array.from(X.options.values()):X.options).map((Y,W)=>f(Y._def,{...Q,currentPath:[...Q.currentPath,"anyOf",`${W}`]})).filter((Y)=>!!Y&&(!Q.strictUnions||typeof Y==="object"&&Object.keys(Y).length>0));return $.length?{anyOf:$}:void 0};function c5(X,Q){if(["ZodString","ZodNumber","ZodBigInt","ZodBoolean","ZodNull"].includes(X.innerType._def.typeName)&&(!X.innerType._def.checks||!X.innerType._def.checks.length)){if(Q.target==="openApi3")return{type:gX[X.innerType._def.typeName],nullable:!0};return{type:[gX[X.innerType._def.typeName],"null"]}}if(Q.target==="openApi3"){let Y=f(X.innerType._def,{...Q,currentPath:[...Q.currentPath]});if(Y&&"$ref"in Y)return{allOf:[Y],nullable:!0};return Y&&{...Y,nullable:!0}}let $=f(X.innerType._def,{...Q,currentPath:[...Q.currentPath,"anyOf","0"]});return $&&{anyOf:[$,{type:"null"}]}}function p5(X,Q){let $={type:"number"};if(!X.checks)return $;for(let Y of X.checks)switch(Y.kind){case"int":$.type="integer",m$($,"type",Y.message,Q);break;case"min":if(Q.target==="jsonSchema7")if(Y.inclusive)o($,"minimum",Y.value,Y.message,Q);else o($,"exclusiveMinimum",Y.value,Y.message,Q);else{if(!Y.inclusive)$.exclusiveMinimum=!0;o($,"minimum",Y.value,Y.message,Q)}break;case"max":if(Q.target==="jsonSchema7")if(Y.inclusive)o($,"maximum",Y.value,Y.message,Q);else o($,"exclusiveMaximum",Y.value,Y.message,Q);else{if(!Y.inclusive)$.exclusiveMaximum=!0;o($,"maximum",Y.value,Y.message,Q)}break;case"multipleOf":o($,"multipleOf",Y.value,Y.message,Q);break}return $}function d5(X,Q){let $=Q.target==="openAi",Y={type:"object",properties:{}},W=[],J=X.shape();for(let H in J){let B=J[H];if(B===void 0||B._def===void 0)continue;let z=VN(B);if(z&&$){if(B._def.typeName==="ZodOptional")B=B._def.innerType;if(!B.isNullable())B=B.nullable();z=!1}let K=f(B._def,{...Q,currentPath:[...Q.currentPath,"properties",H],propertyPath:[...Q.currentPath,"properties",H]});if(K===void 0)continue;if(Y.properties[H]=K,!z)W.push(H)}if(W.length)Y.required=W;let G=UN(X,Q);if(G!==void 0)Y.additionalProperties=G;return Y}function UN(X,Q){if(X.catchall._def.typeName!=="ZodNever")return f(X.catchall._def,{...Q,currentPath:[...Q.currentPath,"additionalProperties"]});switch(X.unknownKeys){case"passthrough":return Q.allowedAdditionalProperties;case"strict":return Q.rejectedAdditionalProperties;case"strip":return Q.removeAdditionalStrategy==="strict"?Q.allowedAdditionalProperties:Q.rejectedAdditionalProperties}}function VN(X){try{return X.isOptional()}catch{return!0}}var i5=(X,Q)=>{if(Q.currentPath.toString()===Q.propertyPath?.toString())return f(X.innerType._def,Q);let $=f(X.innerType._def,{...Q,currentPath:[...Q.currentPath,"anyOf","1"]});return $?{anyOf:[{not:B0(Q)},$]}:B0(Q)};var n5=(X,Q)=>{if(Q.pipeStrategy==="input")return f(X.in._def,Q);else if(Q.pipeStrategy==="output")return f(X.out._def,Q);let $=f(X.in._def,{...Q,currentPath:[...Q.currentPath,"allOf","0"]}),Y=f(X.out._def,{...Q,currentPath:[...Q.currentPath,"allOf",$?"1":"0"]});return{allOf:[$,Y].filter((W)=>W!==void 0)}};function r5(X,Q){return f(X.type._def,Q)}function o5(X,Q){let Y={type:"array",uniqueItems:!0,items:f(X.valueType._def,{...Q,currentPath:[...Q.currentPath,"items"]})};if(X.minSize)o(Y,"minItems",X.minSize.value,X.minSize.message,Q);if(X.maxSize)o(Y,"maxItems",X.maxSize.value,X.maxSize.message,Q);return Y}function t5(X,Q){if(X.rest)return{type:"array",minItems:X.items.length,items:X.items.map(($,Y)=>f($._def,{...Q,currentPath:[...Q.currentPath,"items",`${Y}`]})).reduce(($,Y)=>Y===void 0?$:[...$,Y],[]),additionalItems:f(X.rest._def,{...Q,currentPath:[...Q.currentPath,"additionalItems"]})};else return{type:"array",minItems:X.items.length,maxItems:X.items.length,items:X.items.map(($,Y)=>f($._def,{...Q,currentPath:[...Q.currentPath,"items",`${Y}`]})).reduce(($,Y)=>Y===void 0?$:[...$,Y],[])}}function a5(X){return{not:B0(X)}}function s5(X){return B0(X)}var e5=(X,Q)=>{return f(X.innerType._def,Q)};var XG=(X,Q,$)=>{switch(Q){case j.ZodString:return N8(X,$);case j.ZodNumber:return p5(X,$);case j.ZodObject:return d5(X,$);case j.ZodBigInt:return S5(X,$);case j.ZodBoolean:return Z5();case j.ZodDate:return c$(X,$);case j.ZodUndefined:return a5($);case j.ZodNull:return u5($);case j.ZodArray:return P5(X,$);case j.ZodUnion:case j.ZodDiscriminatedUnion:return m5(X,$);case j.ZodIntersection:return _5(X,$);case j.ZodTuple:return t5(X,$);case j.ZodRecord:return O8(X,$);case j.ZodLiteral:return x5(X,$);case j.ZodEnum:return T5(X);case j.ZodNativeEnum:return f5(X);case j.ZodNullable:return c5(X,$);case j.ZodOptional:return i5(X,$);case j.ZodMap:return g5(X,$);case j.ZodSet:return o5(X,$);case j.ZodLazy:return()=>X.getter()._def;case j.ZodPromise:return r5(X,$);case j.ZodNaN:case j.ZodNever:return h5($);case j.ZodEffects:return v5(X,$);case j.ZodAny:return B0($);case j.ZodUnknown:return s5($);case j.ZodDefault:return k5(X,$);case j.ZodBranded:return F8(X,$);case j.ZodReadonly:return e5(X,$);case j.ZodCatch:return C5(X,$);case j.ZodPipeline:return n5(X,$);case j.ZodFunction:case j.ZodVoid:case j.ZodSymbol:return;default:return((Y)=>{return})(Q)}};function f(X,Q,$=!1){let Y=Q.seen.get(X);if(Q.override){let H=Q.override?.(X,Q,Y,$);if(H!==I5)return H}if(Y&&!$){let H=LN(Y,Q);if(H!==void 0)return H}let W={def:X,path:Q.currentPath,jsonSchema:void 0};Q.seen.set(X,W);let J=XG(X,X.typeName,Q),G=typeof J==="function"?f(J(),Q):J;if(G)qN(X,Q,G);if(Q.postProcess){let H=Q.postProcess(G,X,Q);return W.jsonSchema=G,H}return W.jsonSchema=G,G}var LN=(X,Q)=>{switch(Q.$refStrategy){case"root":return{$ref:X.path.join("/")};case"relative":return{$ref:q8(Q.currentPath,X.path)};case"none":case"seen":{if(X.path.length<Q.currentPath.length&&X.path.every(($,Y)=>Q.currentPath[Y]===$))return console.warn(`Recursive reference detected at ${Q.currentPath.join("/")}! Defaulting to any`),B0(Q);return Q.$refStrategy==="seen"?B0(Q):void 0}}},qN=(X,Q,$)=>{if(X.description){if($.description=X.description,Q.markdownDescription)$.markdownDescription=X.description}return $};var i$=(X,Q)=>{let $=b5(Q),Y=typeof Q==="object"&&Q.definitions?Object.entries(Q.definitions).reduce((B,[z,K])=>({...B,[z]:f(K._def,{...$,currentPath:[...$.basePath,$.definitionPath,z]},!0)??B0($)}),{}):void 0,W=typeof Q==="string"?Q:Q?.nameStrategy==="title"?void 0:Q?.name,J=f(X._def,W===void 0?$:{...$,currentPath:[...$.basePath,$.definitionPath,W]},!1)??B0($),G=typeof Q==="object"&&Q.name!==void 0&&Q.nameStrategy==="title"?Q.name:void 0;if(G!==void 0)J.title=G;if($.flags.hasReferencedOpenAiAnyType){if(!Y)Y={};if(!Y[$.openAiAnyTypeName])Y[$.openAiAnyTypeName]={type:["string","number","integer","boolean","array","null"],items:{$ref:$.$refStrategy==="relative"?"1":[...$.basePath,$.definitionPath,$.openAiAnyTypeName].join("/")}}}let H=W===void 0?Y?{...J,[$.definitionPath]:Y}:J:{$ref:[...$.$refStrategy==="relative"?[]:$.basePath,$.definitionPath,W].join("/"),[$.definitionPath]:{...Y,[W]:J}};if($.target==="jsonSchema7")H.$schema="http://json-schema.org/draft-07/schema#";else if($.target==="jsonSchema2019-09"||$.target==="openAi")H.$schema="https://json-schema.org/draft/2019-09/schema#";if($.target==="openAi"&&(("anyOf"in H)||("oneOf"in H)||("allOf"in H)||("type"in H)&&Array.isArray(H.type)))console.warn("Warning: OpenAI may not support schemas with unions as roots! Try wrapping it in an object property.");return H};function FN(X){if(!X)return"draft-7";if(X==="jsonSchema7"||X==="draft-7")return"draft-7";if(X==="jsonSchema2019-09"||X==="draft-2020-12")return"draft-2020-12";return"draft-7"}function n$(X,Q){var $,Y,W;if(m0(X))return N$(X,{target:FN(Q===null||Q===void 0?void 0:Q.target),io:($=Q===null||Q===void 0?void 0:Q.pipeStrategy)!==null&&$!==void 0?$:"input"});return i$(X,{strictUnions:(Y=Q===null||Q===void 0?void 0:Q.strictUnions)!==null&&Y!==void 0?Y:!0,pipeStrategy:(W=Q===null||Q===void 0?void 0:Q.pipeStrategy)!==null&&W!==void 0?W:"input"})}function r$(X){let Q=h1(X),$=Q===null||Q===void 0?void 0:Q.method;if(!$)throw Error("Schema is missing a method literal");let Y=p4($);if(typeof Y!=="string")throw Error("Schema method literal must be a string");return Y}function o$(X,Q){let $=f1(X,Q);if(!$.success)throw $.error;return $.data}var NN=60000;class t${constructor(X){if(this._options=X,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(a4,(Q)=>{this._oncancel(Q)}),this.setNotificationHandler(e4,(Q)=>{this._onprogress(Q)}),this.setRequestHandler(s4,(Q)=>({})),this._taskStore=X===null||X===void 0?void 0:X.taskStore,this._taskMessageQueue=X===null||X===void 0?void 0:X.taskMessageQueue,this._taskStore)this.setRequestHandler(X8,async(Q,$)=>{let Y=await this._taskStore.getTask(Q.params.taskId,$.sessionId);if(!Y)throw new k(x.InvalidParams,"Failed to retrieve task: Task not found");return{...Y}}),this.setRequestHandler($8,async(Q,$)=>{let Y=async()=>{var W;let J=Q.params.taskId;if(this._taskMessageQueue){let H;while(H=await this._taskMessageQueue.dequeue(J,$.sessionId)){if(H.type==="response"||H.type==="error"){let B=H.message,z=B.id,K=this._requestResolvers.get(z);if(K)if(this._requestResolvers.delete(z),H.type==="response")K(B);else{let V=B,L=new k(V.error.code,V.error.message,V.error.data);K(L)}else{let V=H.type==="response"?"Response":"Error";this._onerror(Error(`${V} handler missing for request ${z}`))}continue}await((W=this._transport)===null||W===void 0?void 0:W.send(H.message,{relatedRequestId:$.requestId}))}}let G=await this._taskStore.getTask(J,$.sessionId);if(!G)throw new k(x.InvalidParams,`Task not found: ${J}`);if(!u1(G.status))return await this._waitForTaskUpdate(J,$.signal),await Y();if(u1(G.status)){let H=await this._taskStore.getTaskResult(J,$.sessionId);return this._clearTaskQueue(J),{...H,_meta:{...H._meta,[z1]:{taskId:J}}}}return await Y()};return await Y()}),this.setRequestHandler(Y8,async(Q,$)=>{var Y;try{let{tasks:W,nextCursor:J}=await this._taskStore.listTasks((Y=Q.params)===null||Y===void 0?void 0:Y.cursor,$.sessionId);return{tasks:W,nextCursor:J,_meta:{}}}catch(W){throw new k(x.InvalidParams,`Failed to list tasks: ${W instanceof Error?W.message:String(W)}`)}}),this.setRequestHandler(L5,async(Q,$)=>{try{let Y=await this._taskStore.getTask(Q.params.taskId,$.sessionId);if(!Y)throw new k(x.InvalidParams,`Task not found: ${Q.params.taskId}`);if(u1(Y.status))throw new k(x.InvalidParams,`Cannot cancel task in terminal status: ${Y.status}`);await this._taskStore.updateTaskStatus(Q.params.taskId,"cancelled","Client cancelled task execution.",$.sessionId),this._clearTaskQueue(Q.params.taskId);let W=await this._taskStore.getTask(Q.params.taskId,$.sessionId);if(!W)throw new k(x.InvalidParams,`Task not found after cancellation: ${Q.params.taskId}`);return{_meta:{},...W}}catch(Y){if(Y instanceof k)throw Y;throw new k(x.InvalidRequest,`Failed to cancel task: ${Y instanceof Error?Y.message:String(Y)}`)}})}async _oncancel(X){let Q=this._requestHandlerAbortControllers.get(X.params.requestId);Q===null||Q===void 0||Q.abort(X.params.reason)}_setupTimeout(X,Q,$,Y,W=!1){this._timeoutInfo.set(X,{timeoutId:setTimeout(Y,Q),startTime:Date.now(),timeout:Q,maxTotalTimeout:$,resetTimeoutOnProgress:W,onTimeout:Y})}_resetTimeout(X){let Q=this._timeoutInfo.get(X);if(!Q)return!1;let $=Date.now()-Q.startTime;if(Q.maxTotalTimeout&&$>=Q.maxTotalTimeout)throw this._timeoutInfo.delete(X),k.fromError(x.RequestTimeout,"Maximum total timeout exceeded",{maxTotalTimeout:Q.maxTotalTimeout,totalElapsed:$});return clearTimeout(Q.timeoutId),Q.timeoutId=setTimeout(Q.onTimeout,Q.timeout),!0}_cleanupTimeout(X){let Q=this._timeoutInfo.get(X);if(Q)clearTimeout(Q.timeoutId),this._timeoutInfo.delete(X)}async connect(X){var Q,$,Y;this._transport=X;let W=(Q=this.transport)===null||Q===void 0?void 0:Q.onclose;this._transport.onclose=()=>{W===null||W===void 0||W(),this._onclose()};let J=($=this.transport)===null||$===void 0?void 0:$.onerror;this._transport.onerror=(H)=>{J===null||J===void 0||J(H),this._onerror(H)};let G=(Y=this._transport)===null||Y===void 0?void 0:Y.onmessage;this._transport.onmessage=(H,B)=>{if(G===null||G===void 0||G(H,B),CX(H)||U5(H))this._onresponse(H);else if(Z$(H))this._onrequest(H,B);else if(B5(H))this._onnotification(H);else this._onerror(Error(`Unknown message type: ${JSON.stringify(H)}`))},await this._transport.start()}_onclose(){var X;let Q=this._responseHandlers;this._responseHandlers=new Map,this._progressHandlers.clear(),this._taskProgressTokens.clear(),this._pendingDebouncedNotifications.clear();let $=k.fromError(x.ConnectionClosed,"Connection closed");this._transport=void 0,(X=this.onclose)===null||X===void 0||X.call(this);for(let Y of Q.values())Y($)}_onerror(X){var Q;(Q=this.onerror)===null||Q===void 0||Q.call(this,X)}_onnotification(X){var Q;let $=(Q=this._notificationHandlers.get(X.method))!==null&&Q!==void 0?Q:this.fallbackNotificationHandler;if($===void 0)return;Promise.resolve().then(()=>$(X)).catch((Y)=>this._onerror(Error(`Uncaught error in notification handler: ${Y}`)))}_onrequest(X,Q){var $,Y,W,J,G,H;let B=($=this._requestHandlers.get(X.method))!==null&&$!==void 0?$:this.fallbackRequestHandler,z=this._transport,K=(J=(W=(Y=X.params)===null||Y===void 0?void 0:Y._meta)===null||W===void 0?void 0:W[z1])===null||J===void 0?void 0:J.taskId;if(B===void 0){let q={jsonrpc:"2.0",id:X.id,error:{code:x.MethodNotFound,message:"Method not found"}};if(K&&this._taskMessageQueue)this._enqueueTaskMessage(K,{type:"error",message:q,timestamp:Date.now()},z===null||z===void 0?void 0:z.sessionId).catch((N)=>this._onerror(Error(`Failed to enqueue error response: ${N}`)));else z===null||z===void 0||z.send(q).catch((N)=>this._onerror(Error(`Failed to send an error response: ${N}`)));return}let V=new AbortController;this._requestHandlerAbortControllers.set(X.id,V);let L=(G=X.params)===null||G===void 0?void 0:G.task,U=this._taskStore?this.requestTaskStore(X,z===null||z===void 0?void 0:z.sessionId):void 0,F={signal:V.signal,sessionId:z===null||z===void 0?void 0:z.sessionId,_meta:(H=X.params)===null||H===void 0?void 0:H._meta,sendNotification:async(q)=>{let N={relatedRequestId:X.id};if(K)N.relatedTask={taskId:K};await this.notification(q,N)},sendRequest:async(q,N,w)=>{var M,R;let S={...w,relatedRequestId:X.id};if(K&&!S.relatedTask)S.relatedTask={taskId:K};let C=(R=(M=S.relatedTask)===null||M===void 0?void 0:M.taskId)!==null&&R!==void 0?R:K;if(C&&U)await U.updateTaskStatus(C,"input_required");return await this.request(q,N,S)},authInfo:Q===null||Q===void 0?void 0:Q.authInfo,requestId:X.id,requestInfo:Q===null||Q===void 0?void 0:Q.requestInfo,taskId:K,taskStore:U,taskRequestedTtl:L===null||L===void 0?void 0:L.ttl,closeSSEStream:Q===null||Q===void 0?void 0:Q.closeSSEStream,closeStandaloneSSEStream:Q===null||Q===void 0?void 0:Q.closeStandaloneSSEStream};Promise.resolve().then(()=>{if(L)this.assertTaskHandlerCapability(X.method)}).then(()=>B(X,F)).then(async(q)=>{if(V.signal.aborted)return;let N={result:q,jsonrpc:"2.0",id:X.id};if(K&&this._taskMessageQueue)await this._enqueueTaskMessage(K,{type:"response",message:N,timestamp:Date.now()},z===null||z===void 0?void 0:z.sessionId);else await(z===null||z===void 0?void 0:z.send(N))},async(q)=>{var N;if(V.signal.aborted)return;let w={jsonrpc:"2.0",id:X.id,error:{code:Number.isSafeInteger(q.code)?q.code:x.InternalError,message:(N=q.message)!==null&&N!==void 0?N:"Internal error",...q.data!==void 0&&{data:q.data}}};if(K&&this._taskMessageQueue)await this._enqueueTaskMessage(K,{type:"error",message:w,timestamp:Date.now()},z===null||z===void 0?void 0:z.sessionId);else await(z===null||z===void 0?void 0:z.send(w))}).catch((q)=>this._onerror(Error(`Failed to send response: ${q}`))).finally(()=>{this._requestHandlerAbortControllers.delete(X.id)})}_onprogress(X){let{progressToken:Q,...$}=X.params,Y=Number(Q),W=this._progressHandlers.get(Y);if(!W){this._onerror(Error(`Received a progress notification for an unknown token: ${JSON.stringify(X)}`));return}let J=this._responseHandlers.get(Y),G=this._timeoutInfo.get(Y);if(G&&J&&G.resetTimeoutOnProgress)try{this._resetTimeout(Y)}catch(H){this._responseHandlers.delete(Y),this._progressHandlers.delete(Y),this._cleanupTimeout(Y),J(H);return}W($)}_onresponse(X){let Q=Number(X.id),$=this._requestResolvers.get(Q);if($){if(this._requestResolvers.delete(Q),CX(X))$(X);else{let J=new k(X.error.code,X.error.message,X.error.data);$(J)}return}let Y=this._responseHandlers.get(Q);if(Y===void 0){this._onerror(Error(`Received a response for an unknown message ID: ${JSON.stringify(X)}`));return}this._responseHandlers.delete(Q),this._cleanupTimeout(Q);let W=!1;if(CX(X)&&X.result&&typeof X.result==="object"){let J=X.result;if(J.task&&typeof J.task==="object"){let G=J.task;if(typeof G.taskId==="string")W=!0,this._taskProgressTokens.set(G.taskId,Q)}}if(!W)this._progressHandlers.delete(Q);if(CX(X))Y(X);else{let J=k.fromError(X.error.code,X.error.message,X.error.data);Y(J)}}get transport(){return this._transport}async close(){var X;await((X=this._transport)===null||X===void 0?void 0:X.close())}async*requestStream(X,Q,$){var Y,W,J,G;let{task:H}=$!==null&&$!==void 0?$:{};if(!H){try{yield{type:"result",result:await this.request(X,Q,$)}}catch(z){yield{type:"error",error:z instanceof k?z:new k(x.InternalError,String(z))}}return}let B;try{let z=await this.request(X,_6,$);if(z.task)B=z.task.taskId,yield{type:"taskCreated",task:z.task};else throw new k(x.InternalError,"Task creation did not return a task");while(!0){let K=await this.getTask({taskId:B},$);if(yield{type:"taskStatus",task:K},u1(K.status)){if(K.status==="completed")yield{type:"result",result:await this.getTaskResult({taskId:B},Q,$)};else if(K.status==="failed")yield{type:"error",error:new k(x.InternalError,`Task ${B} failed`)};else if(K.status==="cancelled")yield{type:"error",error:new k(x.InternalError,`Task ${B} was cancelled`)};return}if(K.status==="input_required"){yield{type:"result",result:await this.getTaskResult({taskId:B},Q,$)};return}let V=(J=(Y=K.pollInterval)!==null&&Y!==void 0?Y:(W=this._options)===null||W===void 0?void 0:W.defaultTaskPollInterval)!==null&&J!==void 0?J:1000;await new Promise((L)=>setTimeout(L,V)),(G=$===null||$===void 0?void 0:$.signal)===null||G===void 0||G.throwIfAborted()}}catch(z){yield{type:"error",error:z instanceof k?z:new k(x.InternalError,String(z))}}}request(X,Q,$){let{relatedRequestId:Y,resumptionToken:W,onresumptiontoken:J,task:G,relatedTask:H}=$!==null&&$!==void 0?$:{};return new Promise((B,z)=>{var K,V,L,U,F,q,N;let w=(s)=>{z(s)};if(!this._transport){w(Error("Not connected"));return}if(((K=this._options)===null||K===void 0?void 0:K.enforceStrictCapabilities)===!0)try{if(this.assertCapabilityForMethod(X.method),G)this.assertTaskCapability(X.method)}catch(s){w(s);return}(V=$===null||$===void 0?void 0:$.signal)===null||V===void 0||V.throwIfAborted();let M=this._requestMessageId++,R={...X,jsonrpc:"2.0",id:M};if($===null||$===void 0?void 0:$.onprogress)this._progressHandlers.set(M,$.onprogress),R.params={...X.params,_meta:{...((L=X.params)===null||L===void 0?void 0:L._meta)||{},progressToken:M}};if(G)R.params={...R.params,task:G};if(H)R.params={...R.params,_meta:{...((U=R.params)===null||U===void 0?void 0:U._meta)||{},[z1]:H}};let S=(s)=>{var D0;this._responseHandlers.delete(M),this._progressHandlers.delete(M),this._cleanupTimeout(M),(D0=this._transport)===null||D0===void 0||D0.send({jsonrpc:"2.0",method:"notifications/cancelled",params:{requestId:M,reason:String(s)}},{relatedRequestId:Y,resumptionToken:W,onresumptiontoken:J}).catch((L1)=>this._onerror(Error(`Failed to send cancellation: ${L1}`)));let q0=s instanceof k?s:new k(x.RequestTimeout,String(s));z(q0)};this._responseHandlers.set(M,(s)=>{var D0;if((D0=$===null||$===void 0?void 0:$.signal)===null||D0===void 0?void 0:D0.aborted)return;if(s instanceof Error)return z(s);try{let q0=f1(Q,s.result);if(!q0.success)z(q0.error);else B(q0.data)}catch(q0){z(q0)}}),(F=$===null||$===void 0?void 0:$.signal)===null||F===void 0||F.addEventListener("abort",()=>{var s;S((s=$===null||$===void 0?void 0:$.signal)===null||s===void 0?void 0:s.reason)});let C=(q=$===null||$===void 0?void 0:$.timeout)!==null&&q!==void 0?q:NN,K0=()=>S(k.fromError(x.RequestTimeout,"Request timed out",{timeout:C}));this._setupTimeout(M,C,$===null||$===void 0?void 0:$.maxTotalTimeout,K0,(N=$===null||$===void 0?void 0:$.resetTimeoutOnProgress)!==null&&N!==void 0?N:!1);let U0=H===null||H===void 0?void 0:H.taskId;if(U0){let s=(D0)=>{let q0=this._responseHandlers.get(M);if(q0)q0(D0);else this._onerror(Error(`Response handler missing for side-channeled request ${M}`))};this._requestResolvers.set(M,s),this._enqueueTaskMessage(U0,{type:"request",message:R,timestamp:Date.now()}).catch((D0)=>{this._cleanupTimeout(M),z(D0)})}else this._transport.send(R,{relatedRequestId:Y,resumptionToken:W,onresumptiontoken:J}).catch((s)=>{this._cleanupTimeout(M),z(s)})})}async getTask(X,Q){return this.request({method:"tasks/get",params:X},Q8,Q)}async getTaskResult(X,Q,$){return this.request({method:"tasks/result",params:X},Q,$)}async listTasks(X,Q){return this.request({method:"tasks/list",params:X},W8,Q)}async cancelTask(X,Q){return this.request({method:"tasks/cancel",params:X},q5,Q)}async notification(X,Q){var $,Y,W,J,G;if(!this._transport)throw Error("Not connected");this.assertNotificationCapability(X.method);let H=($=Q===null||Q===void 0?void 0:Q.relatedTask)===null||$===void 0?void 0:$.taskId;if(H){let V={...X,jsonrpc:"2.0",params:{...X.params,_meta:{...((Y=X.params)===null||Y===void 0?void 0:Y._meta)||{},[z1]:Q.relatedTask}}};await this._enqueueTaskMessage(H,{type:"notification",message:V,timestamp:Date.now()});return}if(((J=(W=this._options)===null||W===void 0?void 0:W.debouncedNotificationMethods)!==null&&J!==void 0?J:[]).includes(X.method)&&!X.params&&!(Q===null||Q===void 0?void 0:Q.relatedRequestId)&&!(Q===null||Q===void 0?void 0:Q.relatedTask)){if(this._pendingDebouncedNotifications.has(X.method))return;this._pendingDebouncedNotifications.add(X.method),Promise.resolve().then(()=>{var V,L;if(this._pendingDebouncedNotifications.delete(X.method),!this._transport)return;let U={...X,jsonrpc:"2.0"};if(Q===null||Q===void 0?void 0:Q.relatedTask)U={...U,params:{...U.params,_meta:{...((V=U.params)===null||V===void 0?void 0:V._meta)||{},[z1]:Q.relatedTask}}};(L=this._transport)===null||L===void 0||L.send(U,Q).catch((F)=>this._onerror(F))});return}let K={...X,jsonrpc:"2.0"};if(Q===null||Q===void 0?void 0:Q.relatedTask)K={...K,params:{...K.params,_meta:{...((G=K.params)===null||G===void 0?void 0:G._meta)||{},[z1]:Q.relatedTask}}};await this._transport.send(K,Q)}setRequestHandler(X,Q){let $=r$(X);this.assertRequestHandlerCapability($),this._requestHandlers.set($,(Y,W)=>{let J=o$(X,Y);return Promise.resolve(Q(J,W))})}removeRequestHandler(X){this._requestHandlers.delete(X)}assertCanSetRequestHandler(X){if(this._requestHandlers.has(X))throw Error(`A request handler for ${X} already exists, which would be overridden`)}setNotificationHandler(X,Q){let $=r$(X);this._notificationHandlers.set($,(Y)=>{let W=o$(X,Y);return Promise.resolve(Q(W))})}removeNotificationHandler(X){this._notificationHandlers.delete(X)}_cleanupTaskProgressHandler(X){let Q=this._taskProgressTokens.get(X);if(Q!==void 0)this._progressHandlers.delete(Q),this._taskProgressTokens.delete(X)}async _enqueueTaskMessage(X,Q,$){var Y;if(!this._taskStore||!this._taskMessageQueue)throw Error("Cannot enqueue task message: taskStore and taskMessageQueue are not configured");let W=(Y=this._options)===null||Y===void 0?void 0:Y.maxTaskQueueSize;await this._taskMessageQueue.enqueue(X,Q,$,W)}async _clearTaskQueue(X,Q){if(this._taskMessageQueue){let $=await this._taskMessageQueue.dequeueAll(X,Q);for(let Y of $)if(Y.type==="request"&&Z$(Y.message)){let W=Y.message.id,J=this._requestResolvers.get(W);if(J)J(new k(x.InternalError,"Task cancelled or completed")),this._requestResolvers.delete(W);else this._onerror(Error(`Resolver missing for request ${W} during task ${X} cleanup`))}}}async _waitForTaskUpdate(X,Q){var $,Y,W;let J=(Y=($=this._options)===null||$===void 0?void 0:$.defaultTaskPollInterval)!==null&&Y!==void 0?Y:1000;try{let G=await((W=this._taskStore)===null||W===void 0?void 0:W.getTask(X));if(G===null||G===void 0?void 0:G.pollInterval)J=G.pollInterval}catch(G){}return new Promise((G,H)=>{if(Q.aborted){H(new k(x.InvalidRequest,"Request cancelled"));return}let B=setTimeout(G,J);Q.addEventListener("abort",()=>{clearTimeout(B),H(new k(x.InvalidRequest,"Request cancelled"))},{once:!0})})}requestTaskStore(X,Q){let $=this._taskStore;if(!$)throw Error("No task store configured");return{createTask:async(Y)=>{if(!X)throw Error("No request provided");return await $.createTask(Y,X.id,{method:X.method,params:X.params},Q)},getTask:async(Y)=>{let W=await $.getTask(Y,Q);if(!W)throw new k(x.InvalidParams,"Failed to retrieve task: Task not found");return W},storeTaskResult:async(Y,W,J)=>{await $.storeTaskResult(Y,W,J,Q);let G=await $.getTask(Y,Q);if(G){let H=xX.parse({method:"notifications/tasks/status",params:G});if(await this.notification(H),u1(G.status))this._cleanupTaskProgressHandler(Y)}},getTaskResult:(Y)=>{return $.getTaskResult(Y,Q)},updateTaskStatus:async(Y,W,J)=>{let G=await $.getTask(Y,Q);if(!G)throw new k(x.InvalidParams,`Task "${Y}" not found - it may have been cleaned up`);if(u1(G.status))throw new k(x.InvalidParams,`Cannot update task "${Y}" from terminal status "${G.status}" to "${W}". Terminal states (completed, failed, cancelled) cannot transition to other states.`);await $.updateTaskStatus(Y,W,J,Q);let H=await $.getTask(Y,Q);if(H){let B=xX.parse({method:"notifications/tasks/status",params:H});if(await this.notification(B),u1(H.status))this._cleanupTaskProgressHandler(Y)}},listTasks:(Y)=>{return $.listTasks(Y,Q)}}}}function QG(X){return X!==null&&typeof X==="object"&&!Array.isArray(X)}function $G(X,Q){let $={...X};for(let Y in Q){let W=Y,J=Q[W];if(J===void 0)continue;let G=$[W];if(QG(G)&&QG(J))$[W]={...G,...J};else $[W]=J}return $}var hz=K7(cY(),1),uz=K7(fz(),1);function II(){let X=new hz.Ajv({strict:!1,validateFormats:!0,validateSchema:!1,allErrors:!0});return uz.default(X),X}class eY{constructor(X){this._ajv=X!==null&&X!==void 0?X:II()}getValidator(X){var Q;let $="$id"in X&&typeof X.$id==="string"?(Q=this._ajv.getSchema(X.$id))!==null&&Q!==void 0?Q:this._ajv.compile(X):this._ajv.compile(X);return(Y)=>{if($(Y))return{valid:!0,data:Y,errorMessage:void 0};else return{valid:!1,data:void 0,errorMessage:this._ajv.errorsText($.errors)}}}}class X7{constructor(X){this._server=X}requestStream(X,Q,$){return this._server.requestStream(X,Q,$)}async getTask(X,Q){return this._server.getTask({taskId:X},Q)}async getTaskResult(X,Q,$){return this._server.getTaskResult({taskId:X},Q,$)}async listTasks(X,Q){return this._server.listTasks(X?{cursor:X}:void 0,Q)}async cancelTask(X,Q){return this._server.cancelTask({taskId:X},Q)}}function lz(X,Q,$){var Y;if(!X)throw Error(`${$} does not support task creation (required for ${Q})`);switch(Q){case"tools/call":if(!((Y=X.tools)===null||Y===void 0?void 0:Y.call))throw Error(`${$} does not support task creation for tools/call (required for ${Q})`);break;default:break}}function mz(X,Q,$){var Y,W;if(!X)throw Error(`${$} does not support task creation (required for ${Q})`);switch(Q){case"sampling/createMessage":if(!((Y=X.sampling)===null||Y===void 0?void 0:Y.createMessage))throw Error(`${$} does not support task creation for sampling/createMessage (required for ${Q})`);break;case"elicitation/create":if(!((W=X.elicitation)===null||W===void 0?void 0:W.create))throw Error(`${$} does not support task creation for elicitation/create (required for ${Q})`);break;default:break}}class Q7 extends t${constructor(X,Q){var $,Y;super(Q);if(this._serverInfo=X,this._loggingLevels=new Map,this.LOG_LEVEL_SEVERITY=new Map(yX.options.map((W,J)=>[W,J])),this.isMessageIgnored=(W,J)=>{let G=this._loggingLevels.get(J);return G?this.LOG_LEVEL_SEVERITY.get(W)<this.LOG_LEVEL_SEVERITY.get(G):!1},this._capabilities=($=Q===null||Q===void 0?void 0:Q.capabilities)!==null&&$!==void 0?$:{},this._instructions=Q===null||Q===void 0?void 0:Q.instructions,this._jsonSchemaValidator=(Y=Q===null||Q===void 0?void 0:Q.jsonSchemaValidator)!==null&&Y!==void 0?Y:new eY,this.setRequestHandler(C$,(W)=>this._oninitialize(W)),this.setNotificationHandler(k$,()=>{var W;return(W=this.oninitialized)===null||W===void 0?void 0:W.call(this)}),this._capabilities.logging)this.setRequestHandler(f$,async(W,J)=>{var G;let H=J.sessionId||((G=J.requestInfo)===null||G===void 0?void 0:G.headers["mcp-session-id"])||void 0,{level:B}=W.params,z=yX.safeParse(B);if(z.success)this._loggingLevels.set(H,z.data);return{}})}get experimental(){if(!this._experimental)this._experimental={tasks:new X7(this)};return this._experimental}registerCapabilities(X){if(this.transport)throw Error("Cannot register capabilities after connecting to transport");this._capabilities=$G(this._capabilities,X)}setRequestHandler(X,Q){var $,Y,W;let J=h1(X),G=J===null||J===void 0?void 0:J.method;if(!G)throw Error("Schema is missing a method literal");let H;if(m0(G)){let z=G,K=($=z._zod)===null||$===void 0?void 0:$.def;H=(Y=K===null||K===void 0?void 0:K.value)!==null&&Y!==void 0?Y:z.value}else{let z=G,K=z._def;H=(W=K===null||K===void 0?void 0:K.value)!==null&&W!==void 0?W:z.value}if(typeof H!=="string")throw Error("Schema method literal must be a string");if(H==="tools/call"){let z=async(K,V)=>{let L=f1(y6,K);if(!L.success){let N=L.error instanceof Error?L.error.message:String(L.error);throw new k(x.InvalidParams,`Invalid tools/call request: ${N}`)}let{params:U}=L.data,F=await Promise.resolve(Q(K,V));if(U.task){let N=f1(_6,F);if(!N.success){let w=N.error instanceof Error?N.error.message:String(N.error);throw new k(x.InvalidParams,`Invalid task creation result: ${w}`)}return N.data}let q=f1(U8,F);if(!q.success){let N=q.error instanceof Error?q.error.message:String(q.error);throw new k(x.InvalidParams,`Invalid tools/call result: ${N}`)}return q.data};return super.setRequestHandler(X,z)}return super.setRequestHandler(X,Q)}assertCapabilityForMethod(X){var Q,$,Y;switch(X){case"sampling/createMessage":if(!((Q=this._clientCapabilities)===null||Q===void 0?void 0:Q.sampling))throw Error(`Client does not support sampling (required for ${X})`);break;case"elicitation/create":if(!(($=this._clientCapabilities)===null||$===void 0?void 0:$.elicitation))throw Error(`Client does not support elicitation (required for ${X})`);break;case"roots/list":if(!((Y=this._clientCapabilities)===null||Y===void 0?void 0:Y.roots))throw Error(`Client does not support listing roots (required for ${X})`);break;case"ping":break}}assertNotificationCapability(X){var Q,$;switch(X){case"notifications/message":if(!this._capabilities.logging)throw Error(`Server does not support logging (required for ${X})`);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 ${X})`);break;case"notifications/tools/list_changed":if(!this._capabilities.tools)throw Error(`Server does not support notifying of tool list changes (required for ${X})`);break;case"notifications/prompts/list_changed":if(!this._capabilities.prompts)throw Error(`Server does not support notifying of prompt list changes (required for ${X})`);break;case"notifications/elicitation/complete":if(!(($=(Q=this._clientCapabilities)===null||Q===void 0?void 0:Q.elicitation)===null||$===void 0?void 0:$.url))throw Error(`Client does not support URL elicitation (required for ${X})`);break;case"notifications/cancelled":break;case"notifications/progress":break}}assertRequestHandlerCapability(X){if(!this._capabilities)return;switch(X){case"completion/complete":if(!this._capabilities.completions)throw Error(`Server does not support completions (required for ${X})`);break;case"logging/setLevel":if(!this._capabilities.logging)throw Error(`Server does not support logging (required for ${X})`);break;case"prompts/get":case"prompts/list":if(!this._capabilities.prompts)throw Error(`Server does not support prompts (required for ${X})`);break;case"resources/list":case"resources/templates/list":case"resources/read":if(!this._capabilities.resources)throw Error(`Server does not support resources (required for ${X})`);break;case"tools/call":case"tools/list":if(!this._capabilities.tools)throw Error(`Server does not support tools (required for ${X})`);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 ${X})`);break;case"ping":case"initialize":break}}assertTaskCapability(X){var Q,$;mz(($=(Q=this._clientCapabilities)===null||Q===void 0?void 0:Q.tasks)===null||$===void 0?void 0:$.requests,X,"Client")}assertTaskHandlerCapability(X){var Q;if(!this._capabilities)return;lz((Q=this._capabilities.tasks)===null||Q===void 0?void 0:Q.requests,X,"Server")}async _oninitialize(X){let Q=X.params.protocolVersion;return this._clientCapabilities=X.params.capabilities,this._clientVersion=X.params.clientInfo,{protocolVersion:Y5.includes(Q)?Q:P$,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"},t4)}async createMessage(X,Q){var $,Y;if(X.tools||X.toolChoice){if(!((Y=($=this._clientCapabilities)===null||$===void 0?void 0:$.sampling)===null||Y===void 0?void 0:Y.tools))throw Error("Client does not support sampling tools capability.")}if(X.messages.length>0){let W=X.messages[X.messages.length-1],J=Array.isArray(W.content)?W.content:[W.content],G=J.some((K)=>K.type==="tool_result"),H=X.messages.length>1?X.messages[X.messages.length-2]:void 0,B=H?Array.isArray(H.content)?H.content:[H.content]:[],z=B.some((K)=>K.type==="tool_use");if(G){if(J.some((K)=>K.type!=="tool_result"))throw Error("The last message must contain only tool_result content if any is present");if(!z)throw Error("tool_result blocks are not matching any tool_use from the previous message")}if(z){let K=new Set(B.filter((L)=>L.type==="tool_use").map((L)=>L.id)),V=new Set(J.filter((L)=>L.type==="tool_result").map((L)=>L.toolUseId));if(K.size!==V.size||![...K].every((L)=>V.has(L)))throw Error("ids of tool_result blocks and tool_use blocks from previous message do not match")}}if(X.tools)return this.request({method:"sampling/createMessage",params:X},u$,Q);return this.request({method:"sampling/createMessage",params:X},h$,Q)}async elicitInput(X,Q){var $,Y,W,J,G;switch(($=X.mode)!==null&&$!==void 0?$:"form"){case"url":{if(!((W=(Y=this._clientCapabilities)===null||Y===void 0?void 0:Y.elicitation)===null||W===void 0?void 0:W.url))throw Error("Client does not support url elicitation.");let B=X;return this.request({method:"elicitation/create",params:B},V8,Q)}case"form":{if(!((G=(J=this._clientCapabilities)===null||J===void 0?void 0:J.elicitation)===null||G===void 0?void 0:G.form))throw Error("Client does not support form elicitation.");let B=X.mode==="form"?X:{...X,mode:"form"},z=await this.request({method:"elicitation/create",params:B},V8,Q);if(z.action==="accept"&&z.content&&B.requestedSchema)try{let V=this._jsonSchemaValidator.getValidator(B.requestedSchema)(z.content);if(!V.valid)throw new k(x.InvalidParams,`Elicitation response content does not match requested schema: ${V.errorMessage}`)}catch(K){if(K instanceof k)throw K;throw new k(x.InternalError,`Error validating elicitation response: ${K instanceof Error?K.message:String(K)}`)}return z}}}createElicitationCompletionNotifier(X,Q){var $,Y;if(!((Y=($=this._clientCapabilities)===null||$===void 0?void 0:$.elicitation)===null||Y===void 0?void 0:Y.url))throw Error("Client does not support URL elicitation (required for notifications/elicitation/complete)");return()=>this.notification({method:"notifications/elicitation/complete",params:{elicitationId:X}},Q)}async listRoots(X,Q){return this.request({method:"roots/list",params:X},l$,Q)}async sendLoggingMessage(X,Q){if(this._capabilities.logging){if(!this.isMessageIgnored(X.level,Q))return this.notification({method:"notifications/message",params:X})}}async sendResourceUpdated(X){return this.notification({method:"notifications/resources/updated",params:X})}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 pz=Symbol.for("mcp.completable");function dz(X){return!!X&&typeof X==="object"&&pz in X}function iz(X){let Q=X[pz];return Q===null||Q===void 0?void 0:Q.complete}var cz;(function(X){X.Completable="McpCompletable"})(cz||(cz={}));var EI=/^[A-Za-z0-9._-]{1,128}$/;function bI(X){let Q=[];if(X.length===0)return{isValid:!1,warnings:["Tool name cannot be empty"]};if(X.length>128)return{isValid:!1,warnings:[`Tool name exceeds maximum length of 128 characters (current: ${X.length})`]};if(X.includes(" "))Q.push("Tool name contains spaces, which may cause parsing issues");if(X.includes(","))Q.push("Tool name contains commas, which may cause parsing issues");if(X.startsWith("-")||X.endsWith("-"))Q.push("Tool name starts or ends with a dash, which may cause parsing issues in some contexts");if(X.startsWith(".")||X.endsWith("."))Q.push("Tool name starts or ends with a dot, which may cause parsing issues in some contexts");if(!EI.test(X)){let $=X.split("").filter((Y)=>!/[A-Za-z0-9._-]/.test(Y)).filter((Y,W,J)=>J.indexOf(Y)===W);return Q.push(`Tool name contains invalid characters: ${$.map((Y)=>`"${Y}"`).join(", ")}`,"Allowed characters are: A-Z, a-z, 0-9, underscore (_), dash (-), and dot (.)"),{isValid:!1,warnings:Q}}return{isValid:!0,warnings:Q}}function PI(X,Q){if(Q.length>0){console.warn(`Tool name validation warning for "${X}":`);for(let $ of Q)console.warn(` - ${$}`);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 $7(X){let Q=bI(X);return PI(X,Q.warnings),Q.isValid}class Y7{constructor(X){this._mcpServer=X}registerToolTask(X,Q,$){let Y={taskSupport:"required",...Q.execution};if(Y.taskSupport==="forbidden")throw Error(`Cannot register task-based tool '${X}' with taskSupport 'forbidden'. Use registerTool() instead.`);return this._mcpServer._createRegisteredTool(X,Q.title,Q.description,Q.inputSchema,Q.outputSchema,Q.annotations,Y,Q._meta,$)}}class J7{constructor(X,Q){this._registeredResources={},this._registeredResourceTemplates={},this._registeredTools={},this._registeredPrompts={},this._toolHandlersInitialized=!1,this._completionHandlerInitialized=!1,this._resourceHandlersInitialized=!1,this._promptHandlersInitialized=!1,this.server=new Q7(X,Q)}get experimental(){if(!this._experimental)this._experimental={tasks:new Y7(this)};return this._experimental}async connect(X){return await this.server.connect(X)}async close(){await this.server.close()}setToolRequestHandlers(){if(this._toolHandlersInitialized)return;this.server.assertCanSetRequestHandler(r1(K8)),this.server.assertCanSetRequestHandler(r1(y6)),this.server.registerCapabilities({tools:{listChanged:!0}}),this.server.setRequestHandler(K8,()=>({tools:Object.entries(this._registeredTools).filter(([,X])=>X.enabled).map(([X,Q])=>{let $={name:X,title:Q.title,description:Q.description,inputSchema:(()=>{let Y=v6(Q.inputSchema);return Y?n$(Y,{strictUnions:!0,pipeStrategy:"input"}):SI})(),annotations:Q.annotations,execution:Q.execution,_meta:Q._meta};if(Q.outputSchema){let Y=v6(Q.outputSchema);if(Y)$.outputSchema=n$(Y,{strictUnions:!0,pipeStrategy:"output"})}return $})})),this.server.setRequestHandler(y6,async(X,Q)=>{var $;try{let Y=this._registeredTools[X.params.name];if(!Y)throw new k(x.InvalidParams,`Tool ${X.params.name} not found`);if(!Y.enabled)throw new k(x.InvalidParams,`Tool ${X.params.name} disabled`);let W=!!X.params.task,J=($=Y.execution)===null||$===void 0?void 0:$.taskSupport,G="createTask"in Y.handler;if((J==="required"||J==="optional")&&!G)throw new k(x.InternalError,`Tool ${X.params.name} has taskSupport '${J}' but was not registered with registerToolTask`);if(J==="required"&&!W)throw new k(x.MethodNotFound,`Tool ${X.params.name} requires task augmentation (taskSupport: 'required')`);if(J==="optional"&&!W&&G)return await this.handleAutomaticTaskPolling(Y,X,Q);let H=await this.validateToolInput(Y,X.params.arguments,X.params.name),B=await this.executeToolHandler(Y,H,Q);if(W)return B;return await this.validateToolOutput(Y,B,X.params.name),B}catch(Y){if(Y instanceof k){if(Y.code===x.UrlElicitationRequired)throw Y}return this.createToolError(Y instanceof Error?Y.message:String(Y))}}),this._toolHandlersInitialized=!0}createToolError(X){return{content:[{type:"text",text:X}],isError:!0}}async validateToolInput(X,Q,$){if(!X.inputSchema)return;let Y=v6(X.inputSchema),W=Y!==null&&Y!==void 0?Y:X.inputSchema,J=await m4(W,Q);if(!J.success){let G="error"in J?J.error:"Unknown error",H=c4(G);throw new k(x.InvalidParams,`Input validation error: Invalid arguments for tool ${$}: ${H}`)}return J.data}async validateToolOutput(X,Q,$){if(!X.outputSchema)return;if(!("content"in Q))return;if(Q.isError)return;if(!Q.structuredContent)throw new k(x.InvalidParams,`Output validation error: Tool ${$} has an output schema but no structured content was provided`);let Y=v6(X.outputSchema),W=await m4(Y,Q.structuredContent);if(!W.success){let J="error"in W?W.error:"Unknown error",G=c4(J);throw new k(x.InvalidParams,`Output validation error: Invalid structured content for tool ${$}: ${G}`)}}async executeToolHandler(X,Q,$){let Y=X.handler;if("createTask"in Y){if(!$.taskStore)throw Error("No task store provided.");let J={...$,taskStore:$.taskStore};if(X.inputSchema)return await Promise.resolve(Y.createTask(Q,J));else return await Promise.resolve(Y.createTask(J))}if(X.inputSchema)return await Promise.resolve(Y(Q,$));else return await Promise.resolve(Y($))}async handleAutomaticTaskPolling(X,Q,$){var Y;if(!$.taskStore)throw Error("No task store provided for task-capable tool.");let W=await this.validateToolInput(X,Q.params.arguments,Q.params.name),J=X.handler,G={...$,taskStore:$.taskStore},H=W?await Promise.resolve(J.createTask(W,G)):await Promise.resolve(J.createTask(G)),B=H.task.taskId,z=H.task,K=(Y=z.pollInterval)!==null&&Y!==void 0?Y:5000;while(z.status!=="completed"&&z.status!=="failed"&&z.status!=="cancelled"){await new Promise((L)=>setTimeout(L,K));let V=await $.taskStore.getTask(B);if(!V)throw new k(x.InternalError,`Task ${B} not found during polling`);z=V}return await $.taskStore.getTaskResult(B)}setCompletionRequestHandler(){if(this._completionHandlerInitialized)return;this.server.assertCanSetRequestHandler(r1(L8)),this.server.registerCapabilities({completions:{}}),this.server.setRequestHandler(L8,async(X)=>{switch(X.params.ref.type){case"ref/prompt":return A5(X),this.handlePromptCompletion(X,X.params.ref);case"ref/resource":return M5(X),this.handleResourceCompletion(X,X.params.ref);default:throw new k(x.InvalidParams,`Invalid completion reference: ${X.params.ref}`)}}),this._completionHandlerInitialized=!0}async handlePromptCompletion(X,Q){let $=this._registeredPrompts[Q.name];if(!$)throw new k(x.InvalidParams,`Prompt ${Q.name} not found`);if(!$.enabled)throw new k(x.InvalidParams,`Prompt ${Q.name} disabled`);if(!$.argsSchema)return H4;let Y=h1($.argsSchema),W=Y===null||Y===void 0?void 0:Y[X.params.argument.name];if(!dz(W))return H4;let J=iz(W);if(!J)return H4;let G=await J(X.params.argument.value,X.params.context);return rz(G)}async handleResourceCompletion(X,Q){let $=Object.values(this._registeredResourceTemplates).find((J)=>J.resourceTemplate.uriTemplate.toString()===Q.uri);if(!$){if(this._registeredResources[Q.uri])return H4;throw new k(x.InvalidParams,`Resource template ${X.params.ref.uri} not found`)}let Y=$.resourceTemplate.completeCallback(X.params.argument.name);if(!Y)return H4;let W=await Y(X.params.argument.value,X.params.context);return rz(W)}setResourceRequestHandlers(){if(this._resourceHandlersInitialized)return;this.server.assertCanSetRequestHandler(r1(J8)),this.server.assertCanSetRequestHandler(r1(G8)),this.server.assertCanSetRequestHandler(r1(H8)),this.server.registerCapabilities({resources:{listChanged:!0}}),this.server.setRequestHandler(J8,async(X,Q)=>{let $=Object.entries(this._registeredResources).filter(([W,J])=>J.enabled).map(([W,J])=>({uri:W,name:J.name,...J.metadata})),Y=[];for(let W of Object.values(this._registeredResourceTemplates)){if(!W.resourceTemplate.listCallback)continue;let J=await W.resourceTemplate.listCallback(Q);for(let G of J.resources)Y.push({...W.metadata,...G})}return{resources:[...$,...Y]}}),this.server.setRequestHandler(G8,async()=>{return{resourceTemplates:Object.entries(this._registeredResourceTemplates).map(([Q,$])=>({name:Q,uriTemplate:$.resourceTemplate.uriTemplate.toString(),...$.metadata}))}}),this.server.setRequestHandler(H8,async(X,Q)=>{let $=new URL(X.params.uri),Y=this._registeredResources[$.toString()];if(Y){if(!Y.enabled)throw new k(x.InvalidParams,`Resource ${$} disabled`);return Y.readCallback($,Q)}for(let W of Object.values(this._registeredResourceTemplates)){let J=W.resourceTemplate.uriTemplate.match($.toString());if(J)return W.readCallback($,J,Q)}throw new k(x.InvalidParams,`Resource ${$} not found`)}),this.setCompletionRequestHandler(),this._resourceHandlersInitialized=!0}setPromptRequestHandlers(){if(this._promptHandlersInitialized)return;this.server.assertCanSetRequestHandler(r1(B8)),this.server.assertCanSetRequestHandler(r1(z8)),this.server.registerCapabilities({prompts:{listChanged:!0}}),this.server.setRequestHandler(B8,()=>({prompts:Object.entries(this._registeredPrompts).filter(([,X])=>X.enabled).map(([X,Q])=>{return{name:X,title:Q.title,description:Q.description,arguments:Q.argsSchema?CI(Q.argsSchema):void 0}})})),this.server.setRequestHandler(z8,async(X,Q)=>{let $=this._registeredPrompts[X.params.name];if(!$)throw new k(x.InvalidParams,`Prompt ${X.params.name} not found`);if(!$.enabled)throw new k(x.InvalidParams,`Prompt ${X.params.name} disabled`);if($.argsSchema){let Y=v6($.argsSchema),W=await m4(Y,X.params.arguments);if(!W.success){let H="error"in W?W.error:"Unknown error",B=c4(H);throw new k(x.InvalidParams,`Invalid arguments for prompt ${X.params.name}: ${B}`)}let J=W.data,G=$.callback;return await Promise.resolve(G(J,Q))}else{let Y=$.callback;return await Promise.resolve(Y(Q))}}),this.setCompletionRequestHandler(),this._promptHandlersInitialized=!0}resource(X,Q,...$){let Y;if(typeof $[0]==="object")Y=$.shift();let W=$[0];if(typeof Q==="string"){if(this._registeredResources[Q])throw Error(`Resource ${Q} is already registered`);let J=this._createRegisteredResource(X,void 0,Q,Y,W);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),J}else{if(this._registeredResourceTemplates[X])throw Error(`Resource template ${X} is already registered`);let J=this._createRegisteredResourceTemplate(X,void 0,Q,Y,W);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),J}}registerResource(X,Q,$,Y){if(typeof Q==="string"){if(this._registeredResources[Q])throw Error(`Resource ${Q} is already registered`);let W=this._createRegisteredResource(X,$.title,Q,$,Y);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),W}else{if(this._registeredResourceTemplates[X])throw Error(`Resource template ${X} is already registered`);let W=this._createRegisteredResourceTemplate(X,$.title,Q,$,Y);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),W}}_createRegisteredResource(X,Q,$,Y,W){let J={name:X,title:Q,metadata:Y,readCallback:W,enabled:!0,disable:()=>J.update({enabled:!1}),enable:()=>J.update({enabled:!0}),remove:()=>J.update({uri:null}),update:(G)=>{if(typeof G.uri<"u"&&G.uri!==$){if(delete this._registeredResources[$],G.uri)this._registeredResources[G.uri]=J}if(typeof G.name<"u")J.name=G.name;if(typeof G.title<"u")J.title=G.title;if(typeof G.metadata<"u")J.metadata=G.metadata;if(typeof G.callback<"u")J.readCallback=G.callback;if(typeof G.enabled<"u")J.enabled=G.enabled;this.sendResourceListChanged()}};return this._registeredResources[$]=J,J}_createRegisteredResourceTemplate(X,Q,$,Y,W){let J={resourceTemplate:$,title:Q,metadata:Y,readCallback:W,enabled:!0,disable:()=>J.update({enabled:!1}),enable:()=>J.update({enabled:!0}),remove:()=>J.update({name:null}),update:(G)=>{if(typeof G.name<"u"&&G.name!==X){if(delete this._registeredResourceTemplates[X],G.name)this._registeredResourceTemplates[G.name]=J}if(typeof G.title<"u")J.title=G.title;if(typeof G.template<"u")J.resourceTemplate=G.template;if(typeof G.metadata<"u")J.metadata=G.metadata;if(typeof G.callback<"u")J.readCallback=G.callback;if(typeof G.enabled<"u")J.enabled=G.enabled;this.sendResourceListChanged()}};return this._registeredResourceTemplates[X]=J,J}_createRegisteredPrompt(X,Q,$,Y,W){let J={title:Q,description:$,argsSchema:Y===void 0?void 0:k6(Y),callback:W,enabled:!0,disable:()=>J.update({enabled:!1}),enable:()=>J.update({enabled:!0}),remove:()=>J.update({name:null}),update:(G)=>{if(typeof G.name<"u"&&G.name!==X){if(delete this._registeredPrompts[X],G.name)this._registeredPrompts[G.name]=J}if(typeof G.title<"u")J.title=G.title;if(typeof G.description<"u")J.description=G.description;if(typeof G.argsSchema<"u")J.argsSchema=k6(G.argsSchema);if(typeof G.callback<"u")J.callback=G.callback;if(typeof G.enabled<"u")J.enabled=G.enabled;this.sendPromptListChanged()}};return this._registeredPrompts[X]=J,J}_createRegisteredTool(X,Q,$,Y,W,J,G,H,B){$7(X);let z={title:Q,description:$,inputSchema:nz(Y),outputSchema:nz(W),annotations:J,execution:G,_meta:H,handler:B,enabled:!0,disable:()=>z.update({enabled:!1}),enable:()=>z.update({enabled:!0}),remove:()=>z.update({name:null}),update:(K)=>{if(typeof K.name<"u"&&K.name!==X){if(typeof K.name==="string")$7(K.name);if(delete this._registeredTools[X],K.name)this._registeredTools[K.name]=z}if(typeof K.title<"u")z.title=K.title;if(typeof K.description<"u")z.description=K.description;if(typeof K.paramsSchema<"u")z.inputSchema=k6(K.paramsSchema);if(typeof K.callback<"u")z.handler=K.callback;if(typeof K.annotations<"u")z.annotations=K.annotations;if(typeof K._meta<"u")z._meta=K._meta;if(typeof K.enabled<"u")z.enabled=K.enabled;this.sendToolListChanged()}};return this._registeredTools[X]=z,this.setToolRequestHandlers(),this.sendToolListChanged(),z}tool(X,...Q){if(this._registeredTools[X])throw Error(`Tool ${X} is already registered`);let $,Y,W,J;if(typeof Q[0]==="string")$=Q.shift();if(Q.length>1){let H=Q[0];if(W7(H)){if(Y=Q.shift(),Q.length>1&&typeof Q[0]==="object"&&Q[0]!==null&&!W7(Q[0]))J=Q.shift()}else if(typeof H==="object"&&H!==null)J=Q.shift()}let G=Q[0];return this._createRegisteredTool(X,void 0,$,Y,W,J,{taskSupport:"forbidden"},void 0,G)}registerTool(X,Q,$){if(this._registeredTools[X])throw Error(`Tool ${X} is already registered`);let{title:Y,description:W,inputSchema:J,outputSchema:G,annotations:H,_meta:B}=Q;return this._createRegisteredTool(X,Y,W,J,G,H,{taskSupport:"forbidden"},B,$)}prompt(X,...Q){if(this._registeredPrompts[X])throw Error(`Prompt ${X} is already registered`);let $;if(typeof Q[0]==="string")$=Q.shift();let Y;if(Q.length>1)Y=Q.shift();let W=Q[0],J=this._createRegisteredPrompt(X,void 0,$,Y,W);return this.setPromptRequestHandlers(),this.sendPromptListChanged(),J}registerPrompt(X,Q,$){if(this._registeredPrompts[X])throw Error(`Prompt ${X} is already registered`);let{title:Y,description:W,argsSchema:J}=Q,G=this._createRegisteredPrompt(X,Y,W,J,$);return this.setPromptRequestHandlers(),this.sendPromptListChanged(),G}isConnected(){return this.server.transport!==void 0}async sendLoggingMessage(X,Q){return this.server.sendLoggingMessage(X,Q)}sendResourceListChanged(){if(this.isConnected())this.server.sendResourceListChanged()}sendToolListChanged(){if(this.isConnected())this.server.sendToolListChanged()}sendPromptListChanged(){if(this.isConnected())this.server.sendPromptListChanged()}}var SI={type:"object",properties:{}};function oz(X){return X!==null&&typeof X==="object"&&"parse"in X&&typeof X.parse==="function"&&"safeParse"in X&&typeof X.safeParse==="function"}function ZI(X){return"_def"in X||"_zod"in X||oz(X)}function W7(X){if(typeof X!=="object"||X===null)return!1;if(ZI(X))return!1;if(Object.keys(X).length===0)return!0;return Object.values(X).some(oz)}function nz(X){if(!X)return;if(W7(X))return k6(X);return X}function CI(X){let Q=h1(X);if(!Q)return[];return Object.entries(Q).map(([$,Y])=>{let W=_J(Y),J=xJ(Y);return{name:$,description:W,required:!J}})}function r1(X){let Q=h1(X),$=Q===null||Q===void 0?void 0:Q.method;if(!$)throw Error("Schema is missing a method literal");let Y=p4($);if(typeof Y==="string")return Y;throw Error("Schema method literal must be a string")}function rz(X){return{completion:{values:X.slice(0,100),total:X.length,hasMore:X.length>100}}}var H4={completion:{values:[],hasMore:!1}};function kI(X,Q,$,Y,W){return{name:X,description:Q,inputSchema:$,handler:Y,annotations:W?.annotations}}function vI(X){let Q=new J7({name:X.name,version:X.version??"1.0.0"},{capabilities:{tools:X.tools?{}:void 0}});if(X.tools)X.tools.forEach(($)=>{Q.registerTool($.name,{description:$.description,inputSchema:$.inputSchema,annotations:$.annotations},$.handler)});return{type:"sdk",name:X.name,instance:Q}}function s_({prompt:X,options:Q}){let{systemPrompt:$,settingSources:Y,sandbox:W,...J}=Q??{},G,H;if($===void 0)G="";else if(typeof $==="string")G=$;else if($.type==="preset")H=$.append;let B=J.pathToClaudeCodeExecutable;if(!B){let L6=TI(import.meta.url),q6=tz(L6,"..");B=tz(q6,"cli.js")}process.env.CLAUDE_AGENT_SDK_VERSION="0.2.36";let{abortController:z=F6(),additionalDirectories:K=[],agent:V,agents:L,allowedTools:U=[],betas:F,canUseTool:q,continue:N,cwd:w,debug:M,debugFile:R,disallowedTools:S=[],tools:C,env:K0,executable:U0=M6()?"bun":"node",executableArgs:s=[],extraArgs:D0={},fallbackModel:q0,enableFileCheckpointing:L1,forkSession:P1,hooks:o1,includePartialMessages:c,persistSession:Q9,maxThinkingTokens:r6,maxTurns:o6,maxBudgetUsd:t6,mcpServers:a6,model:B4,outputFormat:E0,permissionMode:S1="default",allowDangerouslySkipPermissions:s6=!1,permissionPromptToolName:az,plugins:sz,resume:ez,resumeSessionAt:XK,sessionId:QK,stderr:$K,strictMcpConfig:YK}=J,G7=E0?.type==="json_schema"?E0.schema:void 0,V6=K0;if(!V6)V6={...process.env};if(!V6.CLAUDE_CODE_ENTRYPOINT)V6.CLAUDE_CODE_ENTRYPOINT="sdk-ts";if(L1)V6.CLAUDE_CODE_ENABLE_SDK_FILE_CHECKPOINTING="true";if(!B)throw Error("pathToClaudeCodeExecutable is required");let $9={},H7=new Map;if(a6)for(let[L6,q6]of Object.entries(a6))if(q6.type==="sdk"&&"instance"in q6)H7.set(L6,q6.instance),$9[L6]={type:"sdk",name:L6};else $9[L6]=q6;let WK=typeof X==="string",B7=new XX({abortController:z,additionalDirectories:K,agent:V,betas:F,cwd:w,debug:M,debugFile:R,executable:U0,executableArgs:s,extraArgs:D0,pathToClaudeCodeExecutable:B,env:V6,forkSession:P1,stderr:$K,maxThinkingTokens:r6,maxTurns:o6,maxBudgetUsd:t6,model:B4,fallbackModel:q0,jsonSchema:G7,permissionMode:S1,allowDangerouslySkipPermissions:s6,permissionPromptToolName:az,continueConversation:N,resume:ez,resumeSessionAt:XK,sessionId:QK,settingSources:Y??[],allowedTools:U,disallowedTools:S,tools:C,mcpServers:$9,strictMcpConfig:YK,canUseTool:!!q,hooks:!!o1,includePartialMessages:c,persistSession:Q9,plugins:sz,sandbox:W,spawnClaudeCodeProcess:J.spawnClaudeCodeProcess}),z7=new $X(B7,WK,q,o1,z,H7,G7,{systemPrompt:G,appendSystemPrompt:H,agents:L});if(typeof X==="string")B7.write(Z0({type:"user",session_id:"",message:{role:"user",content:[{type:"text",text:X}]},parent_tool_use_id:null})+`
|
|
56
56
|
`);else z7.streamInput(X);return z7}function e_(X){return V9(X)}function Xx(X,Q){return UW(X,Q)}async function Qx(X,Q){let Y=[];try{const $=V7(Y,V9(Q),1);await $.send(X);for await(let B of $.stream())if(B.type==="result")return B;throw Error("Session ended without result message")}catch(W){var J=W,G=1}finally{var H=L7(Y,J,G);H&&await H}}export{Xx as unstable_v2_resumeSession,Qx as unstable_v2_prompt,e_ as unstable_v2_createSession,kI as tool,s_ as query,vI as createSdkMcpServer,nU as HOOK_EVENTS,rU as EXIT_REASONS,F1 as AbortError};
|