@contextvm/mcp-sdk 1.27.1-contextvm.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (261) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +141 -0
  3. package/dist/cjs/client/index.d.ts +588 -0
  4. package/dist/cjs/client/index.d.ts.map +1 -0
  5. package/dist/cjs/client/index.js +629 -0
  6. package/dist/cjs/client/index.js.map +1 -0
  7. package/dist/cjs/client/stdio.d.ts +77 -0
  8. package/dist/cjs/client/stdio.d.ts.map +1 -0
  9. package/dist/cjs/client/stdio.js +199 -0
  10. package/dist/cjs/client/stdio.js.map +1 -0
  11. package/dist/cjs/experimental/index.d.ts +13 -0
  12. package/dist/cjs/experimental/index.d.ts.map +1 -0
  13. package/dist/cjs/experimental/index.js +29 -0
  14. package/dist/cjs/experimental/index.js.map +1 -0
  15. package/dist/cjs/experimental/tasks/client.d.ts +121 -0
  16. package/dist/cjs/experimental/tasks/client.d.ts.map +1 -0
  17. package/dist/cjs/experimental/tasks/client.js +188 -0
  18. package/dist/cjs/experimental/tasks/client.js.map +1 -0
  19. package/dist/cjs/experimental/tasks/helpers.d.ts +47 -0
  20. package/dist/cjs/experimental/tasks/helpers.d.ts.map +1 -0
  21. package/dist/cjs/experimental/tasks/helpers.js +68 -0
  22. package/dist/cjs/experimental/tasks/helpers.js.map +1 -0
  23. package/dist/cjs/experimental/tasks/index.d.ts +16 -0
  24. package/dist/cjs/experimental/tasks/index.d.ts.map +1 -0
  25. package/dist/cjs/experimental/tasks/index.js +39 -0
  26. package/dist/cjs/experimental/tasks/index.js.map +1 -0
  27. package/dist/cjs/experimental/tasks/interfaces.d.ts +232 -0
  28. package/dist/cjs/experimental/tasks/interfaces.d.ts.map +1 -0
  29. package/dist/cjs/experimental/tasks/interfaces.js +19 -0
  30. package/dist/cjs/experimental/tasks/interfaces.js.map +1 -0
  31. package/dist/cjs/experimental/tasks/mcp-server.d.ts +77 -0
  32. package/dist/cjs/experimental/tasks/mcp-server.d.ts.map +1 -0
  33. package/dist/cjs/experimental/tasks/mcp-server.js +36 -0
  34. package/dist/cjs/experimental/tasks/mcp-server.js.map +1 -0
  35. package/dist/cjs/experimental/tasks/server.d.ts +170 -0
  36. package/dist/cjs/experimental/tasks/server.d.ts.map +1 -0
  37. package/dist/cjs/experimental/tasks/server.js +250 -0
  38. package/dist/cjs/experimental/tasks/server.js.map +1 -0
  39. package/dist/cjs/experimental/tasks/stores/in-memory.d.ts +94 -0
  40. package/dist/cjs/experimental/tasks/stores/in-memory.d.ts.map +1 -0
  41. package/dist/cjs/experimental/tasks/stores/in-memory.js +251 -0
  42. package/dist/cjs/experimental/tasks/stores/in-memory.js.map +1 -0
  43. package/dist/cjs/experimental/tasks/types.d.ts +10 -0
  44. package/dist/cjs/experimental/tasks/types.d.ts.map +1 -0
  45. package/dist/cjs/experimental/tasks/types.js +28 -0
  46. package/dist/cjs/experimental/tasks/types.js.map +1 -0
  47. package/dist/cjs/inMemory.d.ts +31 -0
  48. package/dist/cjs/inMemory.d.ts.map +1 -0
  49. package/dist/cjs/inMemory.js +51 -0
  50. package/dist/cjs/inMemory.js.map +1 -0
  51. package/dist/cjs/package.json +1 -0
  52. package/dist/cjs/server/completable.d.ts +38 -0
  53. package/dist/cjs/server/completable.d.ts.map +1 -0
  54. package/dist/cjs/server/completable.js +48 -0
  55. package/dist/cjs/server/completable.js.map +1 -0
  56. package/dist/cjs/server/index.d.ts +196 -0
  57. package/dist/cjs/server/index.d.ts.map +1 -0
  58. package/dist/cjs/server/index.js +444 -0
  59. package/dist/cjs/server/index.js.map +1 -0
  60. package/dist/cjs/server/mcp.d.ts +364 -0
  61. package/dist/cjs/server/mcp.d.ts.map +1 -0
  62. package/dist/cjs/server/mcp.js +918 -0
  63. package/dist/cjs/server/mcp.js.map +1 -0
  64. package/dist/cjs/server/stdio.d.ts +28 -0
  65. package/dist/cjs/server/stdio.d.ts.map +1 -0
  66. package/dist/cjs/server/stdio.js +82 -0
  67. package/dist/cjs/server/stdio.js.map +1 -0
  68. package/dist/cjs/server/zod-compat.d.ts +84 -0
  69. package/dist/cjs/server/zod-compat.d.ts.map +1 -0
  70. package/dist/cjs/server/zod-compat.js +244 -0
  71. package/dist/cjs/server/zod-compat.js.map +1 -0
  72. package/dist/cjs/server/zod-json-schema-compat.d.ts +12 -0
  73. package/dist/cjs/server/zod-json-schema-compat.d.ts.map +1 -0
  74. package/dist/cjs/server/zod-json-schema-compat.js +79 -0
  75. package/dist/cjs/server/zod-json-schema-compat.js.map +1 -0
  76. package/dist/cjs/shared/auth-info.d.ts +32 -0
  77. package/dist/cjs/shared/auth-info.d.ts.map +1 -0
  78. package/dist/cjs/shared/auth-info.js +3 -0
  79. package/dist/cjs/shared/auth-info.js.map +1 -0
  80. package/dist/cjs/shared/metadataUtils.d.ts +16 -0
  81. package/dist/cjs/shared/metadataUtils.d.ts.map +1 -0
  82. package/dist/cjs/shared/metadataUtils.js +25 -0
  83. package/dist/cjs/shared/metadataUtils.js.map +1 -0
  84. package/dist/cjs/shared/protocol.d.ts +443 -0
  85. package/dist/cjs/shared/protocol.d.ts.map +1 -0
  86. package/dist/cjs/shared/protocol.js +1104 -0
  87. package/dist/cjs/shared/protocol.js.map +1 -0
  88. package/dist/cjs/shared/responseMessage.d.ts +45 -0
  89. package/dist/cjs/shared/responseMessage.d.ts.map +1 -0
  90. package/dist/cjs/shared/responseMessage.js +23 -0
  91. package/dist/cjs/shared/responseMessage.js.map +1 -0
  92. package/dist/cjs/shared/stdio.d.ts +13 -0
  93. package/dist/cjs/shared/stdio.d.ts.map +1 -0
  94. package/dist/cjs/shared/stdio.js +37 -0
  95. package/dist/cjs/shared/stdio.js.map +1 -0
  96. package/dist/cjs/shared/toolNameValidation.d.ts +31 -0
  97. package/dist/cjs/shared/toolNameValidation.d.ts.map +1 -0
  98. package/dist/cjs/shared/toolNameValidation.js +97 -0
  99. package/dist/cjs/shared/toolNameValidation.js.map +1 -0
  100. package/dist/cjs/shared/transport.d.ts +89 -0
  101. package/dist/cjs/shared/transport.d.ts.map +1 -0
  102. package/dist/cjs/shared/transport.js +43 -0
  103. package/dist/cjs/shared/transport.js.map +1 -0
  104. package/dist/cjs/shared/uriTemplate.d.ts +25 -0
  105. package/dist/cjs/shared/uriTemplate.d.ts.map +1 -0
  106. package/dist/cjs/shared/uriTemplate.js +243 -0
  107. package/dist/cjs/shared/uriTemplate.js.map +1 -0
  108. package/dist/cjs/spec.types.d.ts +2299 -0
  109. package/dist/cjs/spec.types.d.ts.map +1 -0
  110. package/dist/cjs/spec.types.js +27 -0
  111. package/dist/cjs/spec.types.js.map +1 -0
  112. package/dist/cjs/types.d.ts +8137 -0
  113. package/dist/cjs/types.d.ts.map +1 -0
  114. package/dist/cjs/types.js +2092 -0
  115. package/dist/cjs/types.js.map +1 -0
  116. package/dist/cjs/validation/ajv-provider.d.ts +53 -0
  117. package/dist/cjs/validation/ajv-provider.d.ts.map +1 -0
  118. package/dist/cjs/validation/ajv-provider.js +94 -0
  119. package/dist/cjs/validation/ajv-provider.js.map +1 -0
  120. package/dist/cjs/validation/cfworker-provider.d.ts +51 -0
  121. package/dist/cjs/validation/cfworker-provider.d.ts.map +1 -0
  122. package/dist/cjs/validation/cfworker-provider.js +69 -0
  123. package/dist/cjs/validation/cfworker-provider.js.map +1 -0
  124. package/dist/cjs/validation/index.d.ts +29 -0
  125. package/dist/cjs/validation/index.d.ts.map +1 -0
  126. package/dist/cjs/validation/index.js +30 -0
  127. package/dist/cjs/validation/index.js.map +1 -0
  128. package/dist/cjs/validation/types.d.ts +65 -0
  129. package/dist/cjs/validation/types.d.ts.map +1 -0
  130. package/dist/cjs/validation/types.js +3 -0
  131. package/dist/cjs/validation/types.js.map +1 -0
  132. package/dist/esm/client/index.d.ts +588 -0
  133. package/dist/esm/client/index.d.ts.map +1 -0
  134. package/dist/esm/client/index.js +624 -0
  135. package/dist/esm/client/index.js.map +1 -0
  136. package/dist/esm/client/stdio.d.ts +77 -0
  137. package/dist/esm/client/stdio.d.ts.map +1 -0
  138. package/dist/esm/client/stdio.js +191 -0
  139. package/dist/esm/client/stdio.js.map +1 -0
  140. package/dist/esm/experimental/index.d.ts +13 -0
  141. package/dist/esm/experimental/index.d.ts.map +1 -0
  142. package/dist/esm/experimental/index.js +13 -0
  143. package/dist/esm/experimental/index.js.map +1 -0
  144. package/dist/esm/experimental/tasks/client.d.ts +121 -0
  145. package/dist/esm/experimental/tasks/client.d.ts.map +1 -0
  146. package/dist/esm/experimental/tasks/client.js +184 -0
  147. package/dist/esm/experimental/tasks/client.js.map +1 -0
  148. package/dist/esm/experimental/tasks/helpers.d.ts +47 -0
  149. package/dist/esm/experimental/tasks/helpers.d.ts.map +1 -0
  150. package/dist/esm/experimental/tasks/helpers.js +64 -0
  151. package/dist/esm/experimental/tasks/helpers.js.map +1 -0
  152. package/dist/esm/experimental/tasks/index.d.ts +16 -0
  153. package/dist/esm/experimental/tasks/index.d.ts.map +1 -0
  154. package/dist/esm/experimental/tasks/index.js +20 -0
  155. package/dist/esm/experimental/tasks/index.js.map +1 -0
  156. package/dist/esm/experimental/tasks/interfaces.d.ts +232 -0
  157. package/dist/esm/experimental/tasks/interfaces.d.ts.map +1 -0
  158. package/dist/esm/experimental/tasks/interfaces.js +16 -0
  159. package/dist/esm/experimental/tasks/interfaces.js.map +1 -0
  160. package/dist/esm/experimental/tasks/mcp-server.d.ts +77 -0
  161. package/dist/esm/experimental/tasks/mcp-server.d.ts.map +1 -0
  162. package/dist/esm/experimental/tasks/mcp-server.js +32 -0
  163. package/dist/esm/experimental/tasks/mcp-server.js.map +1 -0
  164. package/dist/esm/experimental/tasks/server.d.ts +170 -0
  165. package/dist/esm/experimental/tasks/server.d.ts.map +1 -0
  166. package/dist/esm/experimental/tasks/server.js +246 -0
  167. package/dist/esm/experimental/tasks/server.js.map +1 -0
  168. package/dist/esm/experimental/tasks/stores/in-memory.d.ts +94 -0
  169. package/dist/esm/experimental/tasks/stores/in-memory.d.ts.map +1 -0
  170. package/dist/esm/experimental/tasks/stores/in-memory.js +246 -0
  171. package/dist/esm/experimental/tasks/stores/in-memory.js.map +1 -0
  172. package/dist/esm/experimental/tasks/types.d.ts +10 -0
  173. package/dist/esm/experimental/tasks/types.d.ts.map +1 -0
  174. package/dist/esm/experimental/tasks/types.js +10 -0
  175. package/dist/esm/experimental/tasks/types.js.map +1 -0
  176. package/dist/esm/inMemory.d.ts +31 -0
  177. package/dist/esm/inMemory.d.ts.map +1 -0
  178. package/dist/esm/inMemory.js +47 -0
  179. package/dist/esm/inMemory.js.map +1 -0
  180. package/dist/esm/package.json +1 -0
  181. package/dist/esm/server/completable.d.ts +38 -0
  182. package/dist/esm/server/completable.d.ts.map +1 -0
  183. package/dist/esm/server/completable.js +41 -0
  184. package/dist/esm/server/completable.js.map +1 -0
  185. package/dist/esm/server/index.d.ts +196 -0
  186. package/dist/esm/server/index.d.ts.map +1 -0
  187. package/dist/esm/server/index.js +440 -0
  188. package/dist/esm/server/index.js.map +1 -0
  189. package/dist/esm/server/mcp.d.ts +364 -0
  190. package/dist/esm/server/mcp.d.ts.map +1 -0
  191. package/dist/esm/server/mcp.js +913 -0
  192. package/dist/esm/server/mcp.js.map +1 -0
  193. package/dist/esm/server/stdio.d.ts +28 -0
  194. package/dist/esm/server/stdio.d.ts.map +1 -0
  195. package/dist/esm/server/stdio.js +75 -0
  196. package/dist/esm/server/stdio.js.map +1 -0
  197. package/dist/esm/server/zod-compat.d.ts +84 -0
  198. package/dist/esm/server/zod-compat.d.ts.map +1 -0
  199. package/dist/esm/server/zod-compat.js +209 -0
  200. package/dist/esm/server/zod-compat.js.map +1 -0
  201. package/dist/esm/server/zod-json-schema-compat.d.ts +12 -0
  202. package/dist/esm/server/zod-json-schema-compat.d.ts.map +1 -0
  203. package/dist/esm/server/zod-json-schema-compat.js +51 -0
  204. package/dist/esm/server/zod-json-schema-compat.js.map +1 -0
  205. package/dist/esm/shared/auth-info.d.ts +32 -0
  206. package/dist/esm/shared/auth-info.d.ts.map +1 -0
  207. package/dist/esm/shared/auth-info.js +2 -0
  208. package/dist/esm/shared/auth-info.js.map +1 -0
  209. package/dist/esm/shared/metadataUtils.d.ts +16 -0
  210. package/dist/esm/shared/metadataUtils.d.ts.map +1 -0
  211. package/dist/esm/shared/metadataUtils.js +22 -0
  212. package/dist/esm/shared/metadataUtils.js.map +1 -0
  213. package/dist/esm/shared/protocol.d.ts +443 -0
  214. package/dist/esm/shared/protocol.d.ts.map +1 -0
  215. package/dist/esm/shared/protocol.js +1099 -0
  216. package/dist/esm/shared/protocol.js.map +1 -0
  217. package/dist/esm/shared/responseMessage.d.ts +45 -0
  218. package/dist/esm/shared/responseMessage.d.ts.map +1 -0
  219. package/dist/esm/shared/responseMessage.js +19 -0
  220. package/dist/esm/shared/responseMessage.js.map +1 -0
  221. package/dist/esm/shared/stdio.d.ts +13 -0
  222. package/dist/esm/shared/stdio.d.ts.map +1 -0
  223. package/dist/esm/shared/stdio.js +31 -0
  224. package/dist/esm/shared/stdio.js.map +1 -0
  225. package/dist/esm/shared/toolNameValidation.d.ts +31 -0
  226. package/dist/esm/shared/toolNameValidation.d.ts.map +1 -0
  227. package/dist/esm/shared/toolNameValidation.js +92 -0
  228. package/dist/esm/shared/toolNameValidation.js.map +1 -0
  229. package/dist/esm/shared/transport.d.ts +89 -0
  230. package/dist/esm/shared/transport.d.ts.map +1 -0
  231. package/dist/esm/shared/transport.js +39 -0
  232. package/dist/esm/shared/transport.js.map +1 -0
  233. package/dist/esm/shared/uriTemplate.d.ts +25 -0
  234. package/dist/esm/shared/uriTemplate.d.ts.map +1 -0
  235. package/dist/esm/shared/uriTemplate.js +239 -0
  236. package/dist/esm/shared/uriTemplate.js.map +1 -0
  237. package/dist/esm/spec.types.d.ts +2299 -0
  238. package/dist/esm/spec.types.d.ts.map +1 -0
  239. package/dist/esm/spec.types.js +24 -0
  240. package/dist/esm/spec.types.js.map +1 -0
  241. package/dist/esm/types.d.ts +8137 -0
  242. package/dist/esm/types.d.ts.map +1 -0
  243. package/dist/esm/types.js +2052 -0
  244. package/dist/esm/types.js.map +1 -0
  245. package/dist/esm/validation/ajv-provider.d.ts +53 -0
  246. package/dist/esm/validation/ajv-provider.d.ts.map +1 -0
  247. package/dist/esm/validation/ajv-provider.js +87 -0
  248. package/dist/esm/validation/ajv-provider.js.map +1 -0
  249. package/dist/esm/validation/cfworker-provider.d.ts +51 -0
  250. package/dist/esm/validation/cfworker-provider.d.ts.map +1 -0
  251. package/dist/esm/validation/cfworker-provider.js +65 -0
  252. package/dist/esm/validation/cfworker-provider.js.map +1 -0
  253. package/dist/esm/validation/index.d.ts +29 -0
  254. package/dist/esm/validation/index.d.ts.map +1 -0
  255. package/dist/esm/validation/index.js +29 -0
  256. package/dist/esm/validation/index.js.map +1 -0
  257. package/dist/esm/validation/types.d.ts +65 -0
  258. package/dist/esm/validation/types.d.ts.map +1 -0
  259. package/dist/esm/validation/types.js +2 -0
  260. package/dist/esm/validation/types.js.map +1 -0
  261. package/package.json +124 -0
@@ -0,0 +1,918 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ResourceTemplate = exports.McpServer = void 0;
4
+ const index_js_1 = require("./index.js");
5
+ const zod_compat_js_1 = require("./zod-compat.js");
6
+ const zod_json_schema_compat_js_1 = require("./zod-json-schema-compat.js");
7
+ const types_js_1 = require("../types.js");
8
+ const completable_js_1 = require("./completable.js");
9
+ const uriTemplate_js_1 = require("../shared/uriTemplate.js");
10
+ const toolNameValidation_js_1 = require("../shared/toolNameValidation.js");
11
+ const mcp_server_js_1 = require("../experimental/tasks/mcp-server.js");
12
+ const zod_1 = require("zod");
13
+ /**
14
+ * High-level MCP server that provides a simpler API for working with resources, tools, and prompts.
15
+ * For advanced usage (like sending notifications or setting custom request handlers), use the underlying
16
+ * Server instance available via the `server` property.
17
+ */
18
+ class McpServer {
19
+ constructor(serverInfo, options) {
20
+ this._registeredResources = {};
21
+ this._registeredResourceTemplates = {};
22
+ this._registeredTools = {};
23
+ this._registeredPrompts = {};
24
+ this._toolHandlersInitialized = false;
25
+ this._completionHandlerInitialized = false;
26
+ this._resourceHandlersInitialized = false;
27
+ this._promptHandlersInitialized = false;
28
+ this.server = new index_js_1.Server(serverInfo, options);
29
+ }
30
+ /**
31
+ * Access experimental features.
32
+ *
33
+ * WARNING: These APIs are experimental and may change without notice.
34
+ *
35
+ * @experimental
36
+ */
37
+ get experimental() {
38
+ if (!this._experimental) {
39
+ this._experimental = {
40
+ tasks: new mcp_server_js_1.ExperimentalMcpServerTasks(this)
41
+ };
42
+ }
43
+ return this._experimental;
44
+ }
45
+ /**
46
+ * Attaches to the given transport, starts it, and starts listening for messages.
47
+ *
48
+ * The `server` object assumes ownership of the Transport, replacing any callbacks that have already been set, and expects that it is the only user of the Transport instance going forward.
49
+ */
50
+ async connect(transport) {
51
+ return await this.server.connect(transport);
52
+ }
53
+ /**
54
+ * Closes the connection.
55
+ */
56
+ async close() {
57
+ await this.server.close();
58
+ }
59
+ setToolRequestHandlers() {
60
+ if (this._toolHandlersInitialized) {
61
+ return;
62
+ }
63
+ this.server.assertCanSetRequestHandler(getMethodValue(types_js_1.ListToolsRequestSchema));
64
+ this.server.assertCanSetRequestHandler(getMethodValue(types_js_1.CallToolRequestSchema));
65
+ this.server.registerCapabilities({
66
+ tools: {
67
+ listChanged: true
68
+ }
69
+ });
70
+ this.server.setRequestHandler(types_js_1.ListToolsRequestSchema, () => ({
71
+ tools: Object.entries(this._registeredTools)
72
+ .filter(([, tool]) => tool.enabled)
73
+ .map(([name, tool]) => {
74
+ const toolDefinition = {
75
+ name,
76
+ title: tool.title,
77
+ description: tool.description,
78
+ inputSchema: (() => {
79
+ const obj = (0, zod_compat_js_1.normalizeObjectSchema)(tool.inputSchema);
80
+ return obj
81
+ ? (0, zod_json_schema_compat_js_1.toJsonSchemaCompat)(obj, {
82
+ strictUnions: true,
83
+ pipeStrategy: 'input'
84
+ })
85
+ : EMPTY_OBJECT_JSON_SCHEMA;
86
+ })(),
87
+ annotations: tool.annotations,
88
+ execution: tool.execution,
89
+ _meta: tool._meta
90
+ };
91
+ if (tool.outputSchema) {
92
+ const obj = (0, zod_compat_js_1.normalizeObjectSchema)(tool.outputSchema);
93
+ if (obj) {
94
+ toolDefinition.outputSchema = (0, zod_json_schema_compat_js_1.toJsonSchemaCompat)(obj, {
95
+ strictUnions: true,
96
+ pipeStrategy: 'output'
97
+ });
98
+ }
99
+ }
100
+ return toolDefinition;
101
+ })
102
+ }));
103
+ this.server.setRequestHandler(types_js_1.CallToolRequestSchema, async (request, extra) => {
104
+ try {
105
+ const tool = this._registeredTools[request.params.name];
106
+ if (!tool) {
107
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Tool ${request.params.name} not found`);
108
+ }
109
+ if (!tool.enabled) {
110
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Tool ${request.params.name} disabled`);
111
+ }
112
+ const isTaskRequest = !!request.params.task;
113
+ const taskSupport = tool.execution?.taskSupport;
114
+ const isTaskHandler = 'createTask' in tool.handler;
115
+ // Validate task hint configuration
116
+ if ((taskSupport === 'required' || taskSupport === 'optional') && !isTaskHandler) {
117
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InternalError, `Tool ${request.params.name} has taskSupport '${taskSupport}' but was not registered with registerToolTask`);
118
+ }
119
+ // Handle taskSupport 'required' without task augmentation
120
+ if (taskSupport === 'required' && !isTaskRequest) {
121
+ throw new types_js_1.McpError(types_js_1.ErrorCode.MethodNotFound, `Tool ${request.params.name} requires task augmentation (taskSupport: 'required')`);
122
+ }
123
+ // Handle taskSupport 'optional' without task augmentation - automatic polling
124
+ if (taskSupport === 'optional' && !isTaskRequest && isTaskHandler) {
125
+ return await this.handleAutomaticTaskPolling(tool, request, extra);
126
+ }
127
+ // Normal execution path
128
+ const args = await this.validateToolInput(tool, request.params.arguments, request.params.name);
129
+ const result = await this.executeToolHandler(tool, args, extra);
130
+ // Return CreateTaskResult immediately for task requests
131
+ if (isTaskRequest) {
132
+ return result;
133
+ }
134
+ // Validate output schema for non-task requests
135
+ await this.validateToolOutput(tool, result, request.params.name);
136
+ return result;
137
+ }
138
+ catch (error) {
139
+ if (error instanceof types_js_1.McpError) {
140
+ if (error.code === types_js_1.ErrorCode.UrlElicitationRequired) {
141
+ throw error; // Return the error to the caller without wrapping in CallToolResult
142
+ }
143
+ }
144
+ return this.createToolError(error instanceof Error ? error.message : String(error));
145
+ }
146
+ });
147
+ this._toolHandlersInitialized = true;
148
+ }
149
+ /**
150
+ * Creates a tool error result.
151
+ *
152
+ * @param errorMessage - The error message.
153
+ * @returns The tool error result.
154
+ */
155
+ createToolError(errorMessage) {
156
+ return {
157
+ content: [
158
+ {
159
+ type: 'text',
160
+ text: errorMessage
161
+ }
162
+ ],
163
+ isError: true
164
+ };
165
+ }
166
+ /**
167
+ * Validates tool input arguments against the tool's input schema.
168
+ */
169
+ async validateToolInput(tool, args, toolName) {
170
+ if (!tool.inputSchema) {
171
+ return undefined;
172
+ }
173
+ // Try to normalize to object schema first (for raw shapes and object schemas)
174
+ // If that fails, use the schema directly (for union/intersection/etc)
175
+ const inputObj = (0, zod_compat_js_1.normalizeObjectSchema)(tool.inputSchema);
176
+ const schemaToParse = inputObj ?? tool.inputSchema;
177
+ const parseResult = await (0, zod_compat_js_1.safeParseAsync)(schemaToParse, args);
178
+ if (!parseResult.success) {
179
+ const error = 'error' in parseResult ? parseResult.error : 'Unknown error';
180
+ const errorMessage = (0, zod_compat_js_1.getParseErrorMessage)(error);
181
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Input validation error: Invalid arguments for tool ${toolName}: ${errorMessage}`);
182
+ }
183
+ return parseResult.data;
184
+ }
185
+ /**
186
+ * Validates tool output against the tool's output schema.
187
+ */
188
+ async validateToolOutput(tool, result, toolName) {
189
+ if (!tool.outputSchema) {
190
+ return;
191
+ }
192
+ // Only validate CallToolResult, not CreateTaskResult
193
+ if (!('content' in result)) {
194
+ return;
195
+ }
196
+ if (result.isError) {
197
+ return;
198
+ }
199
+ if (!result.structuredContent) {
200
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Output validation error: Tool ${toolName} has an output schema but no structured content was provided`);
201
+ }
202
+ // if the tool has an output schema, validate structured content
203
+ const outputObj = (0, zod_compat_js_1.normalizeObjectSchema)(tool.outputSchema);
204
+ const parseResult = await (0, zod_compat_js_1.safeParseAsync)(outputObj, result.structuredContent);
205
+ if (!parseResult.success) {
206
+ const error = 'error' in parseResult ? parseResult.error : 'Unknown error';
207
+ const errorMessage = (0, zod_compat_js_1.getParseErrorMessage)(error);
208
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Output validation error: Invalid structured content for tool ${toolName}: ${errorMessage}`);
209
+ }
210
+ }
211
+ /**
212
+ * Executes a tool handler (either regular or task-based).
213
+ */
214
+ async executeToolHandler(tool, args, extra) {
215
+ const handler = tool.handler;
216
+ const isTaskHandler = 'createTask' in handler;
217
+ if (isTaskHandler) {
218
+ if (!extra.taskStore) {
219
+ throw new Error('No task store provided.');
220
+ }
221
+ const taskExtra = { ...extra, taskStore: extra.taskStore };
222
+ if (tool.inputSchema) {
223
+ const typedHandler = handler;
224
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
225
+ return await Promise.resolve(typedHandler.createTask(args, taskExtra));
226
+ }
227
+ else {
228
+ const typedHandler = handler;
229
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
230
+ return await Promise.resolve(typedHandler.createTask(taskExtra));
231
+ }
232
+ }
233
+ if (tool.inputSchema) {
234
+ const typedHandler = handler;
235
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
236
+ return await Promise.resolve(typedHandler(args, extra));
237
+ }
238
+ else {
239
+ const typedHandler = handler;
240
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
241
+ return await Promise.resolve(typedHandler(extra));
242
+ }
243
+ }
244
+ /**
245
+ * Handles automatic task polling for tools with taskSupport 'optional'.
246
+ */
247
+ async handleAutomaticTaskPolling(tool, request, extra) {
248
+ if (!extra.taskStore) {
249
+ throw new Error('No task store provided for task-capable tool.');
250
+ }
251
+ // Validate input and create task
252
+ const args = await this.validateToolInput(tool, request.params.arguments, request.params.name);
253
+ const handler = tool.handler;
254
+ const taskExtra = { ...extra, taskStore: extra.taskStore };
255
+ const createTaskResult = args // undefined only if tool.inputSchema is undefined
256
+ ? await Promise.resolve(handler.createTask(args, taskExtra))
257
+ : // eslint-disable-next-line @typescript-eslint/no-explicit-any
258
+ await Promise.resolve(handler.createTask(taskExtra));
259
+ // Poll until completion
260
+ const taskId = createTaskResult.task.taskId;
261
+ let task = createTaskResult.task;
262
+ const pollInterval = task.pollInterval ?? 5000;
263
+ while (task.status !== 'completed' && task.status !== 'failed' && task.status !== 'cancelled') {
264
+ await new Promise(resolve => setTimeout(resolve, pollInterval));
265
+ const updatedTask = await extra.taskStore.getTask(taskId);
266
+ if (!updatedTask) {
267
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InternalError, `Task ${taskId} not found during polling`);
268
+ }
269
+ task = updatedTask;
270
+ }
271
+ // Return the final result
272
+ return (await extra.taskStore.getTaskResult(taskId));
273
+ }
274
+ setCompletionRequestHandler() {
275
+ if (this._completionHandlerInitialized) {
276
+ return;
277
+ }
278
+ this.server.assertCanSetRequestHandler(getMethodValue(types_js_1.CompleteRequestSchema));
279
+ this.server.registerCapabilities({
280
+ completions: {}
281
+ });
282
+ this.server.setRequestHandler(types_js_1.CompleteRequestSchema, async (request) => {
283
+ switch (request.params.ref.type) {
284
+ case 'ref/prompt':
285
+ (0, types_js_1.assertCompleteRequestPrompt)(request);
286
+ return this.handlePromptCompletion(request, request.params.ref);
287
+ case 'ref/resource':
288
+ (0, types_js_1.assertCompleteRequestResourceTemplate)(request);
289
+ return this.handleResourceCompletion(request, request.params.ref);
290
+ default:
291
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Invalid completion reference: ${request.params.ref}`);
292
+ }
293
+ });
294
+ this._completionHandlerInitialized = true;
295
+ }
296
+ async handlePromptCompletion(request, ref) {
297
+ const prompt = this._registeredPrompts[ref.name];
298
+ if (!prompt) {
299
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Prompt ${ref.name} not found`);
300
+ }
301
+ if (!prompt.enabled) {
302
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Prompt ${ref.name} disabled`);
303
+ }
304
+ if (!prompt.argsSchema) {
305
+ return EMPTY_COMPLETION_RESULT;
306
+ }
307
+ const promptShape = (0, zod_compat_js_1.getObjectShape)(prompt.argsSchema);
308
+ const field = promptShape?.[request.params.argument.name];
309
+ if (!(0, completable_js_1.isCompletable)(field)) {
310
+ return EMPTY_COMPLETION_RESULT;
311
+ }
312
+ const completer = (0, completable_js_1.getCompleter)(field);
313
+ if (!completer) {
314
+ return EMPTY_COMPLETION_RESULT;
315
+ }
316
+ const suggestions = await completer(request.params.argument.value, request.params.context);
317
+ return createCompletionResult(suggestions);
318
+ }
319
+ async handleResourceCompletion(request, ref) {
320
+ const template = Object.values(this._registeredResourceTemplates).find(t => t.resourceTemplate.uriTemplate.toString() === ref.uri);
321
+ if (!template) {
322
+ if (this._registeredResources[ref.uri]) {
323
+ // Attempting to autocomplete a fixed resource URI is not an error in the spec (but probably should be).
324
+ return EMPTY_COMPLETION_RESULT;
325
+ }
326
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Resource template ${request.params.ref.uri} not found`);
327
+ }
328
+ const completer = template.resourceTemplate.completeCallback(request.params.argument.name);
329
+ if (!completer) {
330
+ return EMPTY_COMPLETION_RESULT;
331
+ }
332
+ const suggestions = await completer(request.params.argument.value, request.params.context);
333
+ return createCompletionResult(suggestions);
334
+ }
335
+ setResourceRequestHandlers() {
336
+ if (this._resourceHandlersInitialized) {
337
+ return;
338
+ }
339
+ this.server.assertCanSetRequestHandler(getMethodValue(types_js_1.ListResourcesRequestSchema));
340
+ this.server.assertCanSetRequestHandler(getMethodValue(types_js_1.ListResourceTemplatesRequestSchema));
341
+ this.server.assertCanSetRequestHandler(getMethodValue(types_js_1.ReadResourceRequestSchema));
342
+ this.server.registerCapabilities({
343
+ resources: {
344
+ listChanged: true
345
+ }
346
+ });
347
+ this.server.setRequestHandler(types_js_1.ListResourcesRequestSchema, async (request, extra) => {
348
+ const resources = Object.entries(this._registeredResources)
349
+ .filter(([_, resource]) => resource.enabled)
350
+ .map(([uri, resource]) => ({
351
+ uri,
352
+ name: resource.name,
353
+ ...resource.metadata
354
+ }));
355
+ const templateResources = [];
356
+ for (const template of Object.values(this._registeredResourceTemplates)) {
357
+ if (!template.resourceTemplate.listCallback) {
358
+ continue;
359
+ }
360
+ const result = await template.resourceTemplate.listCallback(extra);
361
+ for (const resource of result.resources) {
362
+ templateResources.push({
363
+ ...template.metadata,
364
+ // the defined resource metadata should override the template metadata if present
365
+ ...resource
366
+ });
367
+ }
368
+ }
369
+ return { resources: [...resources, ...templateResources] };
370
+ });
371
+ this.server.setRequestHandler(types_js_1.ListResourceTemplatesRequestSchema, async () => {
372
+ const resourceTemplates = Object.entries(this._registeredResourceTemplates).map(([name, template]) => ({
373
+ name,
374
+ uriTemplate: template.resourceTemplate.uriTemplate.toString(),
375
+ ...template.metadata
376
+ }));
377
+ return { resourceTemplates };
378
+ });
379
+ this.server.setRequestHandler(types_js_1.ReadResourceRequestSchema, async (request, extra) => {
380
+ const uri = new URL(request.params.uri);
381
+ // First check for exact resource match
382
+ const resource = this._registeredResources[uri.toString()];
383
+ if (resource) {
384
+ if (!resource.enabled) {
385
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Resource ${uri} disabled`);
386
+ }
387
+ return resource.readCallback(uri, extra);
388
+ }
389
+ // Then check templates
390
+ for (const template of Object.values(this._registeredResourceTemplates)) {
391
+ const variables = template.resourceTemplate.uriTemplate.match(uri.toString());
392
+ if (variables) {
393
+ return template.readCallback(uri, variables, extra);
394
+ }
395
+ }
396
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Resource ${uri} not found`);
397
+ });
398
+ this._resourceHandlersInitialized = true;
399
+ }
400
+ setPromptRequestHandlers() {
401
+ if (this._promptHandlersInitialized) {
402
+ return;
403
+ }
404
+ this.server.assertCanSetRequestHandler(getMethodValue(types_js_1.ListPromptsRequestSchema));
405
+ this.server.assertCanSetRequestHandler(getMethodValue(types_js_1.GetPromptRequestSchema));
406
+ this.server.registerCapabilities({
407
+ prompts: {
408
+ listChanged: true
409
+ }
410
+ });
411
+ this.server.setRequestHandler(types_js_1.ListPromptsRequestSchema, () => ({
412
+ prompts: Object.entries(this._registeredPrompts)
413
+ .filter(([, prompt]) => prompt.enabled)
414
+ .map(([name, prompt]) => {
415
+ return {
416
+ name,
417
+ title: prompt.title,
418
+ description: prompt.description,
419
+ arguments: prompt.argsSchema ? promptArgumentsFromSchema(prompt.argsSchema) : undefined
420
+ };
421
+ })
422
+ }));
423
+ this.server.setRequestHandler(types_js_1.GetPromptRequestSchema, async (request, extra) => {
424
+ const prompt = this._registeredPrompts[request.params.name];
425
+ if (!prompt) {
426
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Prompt ${request.params.name} not found`);
427
+ }
428
+ if (!prompt.enabled) {
429
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Prompt ${request.params.name} disabled`);
430
+ }
431
+ if (prompt.argsSchema) {
432
+ const argsObj = (0, zod_compat_js_1.normalizeObjectSchema)(prompt.argsSchema);
433
+ const parseResult = await (0, zod_compat_js_1.safeParseAsync)(argsObj, request.params.arguments);
434
+ if (!parseResult.success) {
435
+ const error = 'error' in parseResult ? parseResult.error : 'Unknown error';
436
+ const errorMessage = (0, zod_compat_js_1.getParseErrorMessage)(error);
437
+ throw new types_js_1.McpError(types_js_1.ErrorCode.InvalidParams, `Invalid arguments for prompt ${request.params.name}: ${errorMessage}`);
438
+ }
439
+ const args = parseResult.data;
440
+ const cb = prompt.callback;
441
+ return await Promise.resolve(cb(args, extra));
442
+ }
443
+ else {
444
+ const cb = prompt.callback;
445
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
446
+ return await Promise.resolve(cb(extra));
447
+ }
448
+ });
449
+ this._promptHandlersInitialized = true;
450
+ }
451
+ resource(name, uriOrTemplate, ...rest) {
452
+ let metadata;
453
+ if (typeof rest[0] === 'object') {
454
+ metadata = rest.shift();
455
+ }
456
+ const readCallback = rest[0];
457
+ if (typeof uriOrTemplate === 'string') {
458
+ if (this._registeredResources[uriOrTemplate]) {
459
+ throw new Error(`Resource ${uriOrTemplate} is already registered`);
460
+ }
461
+ const registeredResource = this._createRegisteredResource(name, undefined, uriOrTemplate, metadata, readCallback);
462
+ this.setResourceRequestHandlers();
463
+ this.sendResourceListChanged();
464
+ return registeredResource;
465
+ }
466
+ else {
467
+ if (this._registeredResourceTemplates[name]) {
468
+ throw new Error(`Resource template ${name} is already registered`);
469
+ }
470
+ const registeredResourceTemplate = this._createRegisteredResourceTemplate(name, undefined, uriOrTemplate, metadata, readCallback);
471
+ this.setResourceRequestHandlers();
472
+ this.sendResourceListChanged();
473
+ return registeredResourceTemplate;
474
+ }
475
+ }
476
+ registerResource(name, uriOrTemplate, config, readCallback) {
477
+ if (typeof uriOrTemplate === 'string') {
478
+ if (this._registeredResources[uriOrTemplate]) {
479
+ throw new Error(`Resource ${uriOrTemplate} is already registered`);
480
+ }
481
+ const registeredResource = this._createRegisteredResource(name, config.title, uriOrTemplate, config, readCallback);
482
+ this.setResourceRequestHandlers();
483
+ this.sendResourceListChanged();
484
+ return registeredResource;
485
+ }
486
+ else {
487
+ if (this._registeredResourceTemplates[name]) {
488
+ throw new Error(`Resource template ${name} is already registered`);
489
+ }
490
+ const registeredResourceTemplate = this._createRegisteredResourceTemplate(name, config.title, uriOrTemplate, config, readCallback);
491
+ this.setResourceRequestHandlers();
492
+ this.sendResourceListChanged();
493
+ return registeredResourceTemplate;
494
+ }
495
+ }
496
+ _createRegisteredResource(name, title, uri, metadata, readCallback) {
497
+ const registeredResource = {
498
+ name,
499
+ title,
500
+ metadata,
501
+ readCallback,
502
+ enabled: true,
503
+ disable: () => registeredResource.update({ enabled: false }),
504
+ enable: () => registeredResource.update({ enabled: true }),
505
+ remove: () => registeredResource.update({ uri: null }),
506
+ update: updates => {
507
+ if (typeof updates.uri !== 'undefined' && updates.uri !== uri) {
508
+ delete this._registeredResources[uri];
509
+ if (updates.uri)
510
+ this._registeredResources[updates.uri] = registeredResource;
511
+ }
512
+ if (typeof updates.name !== 'undefined')
513
+ registeredResource.name = updates.name;
514
+ if (typeof updates.title !== 'undefined')
515
+ registeredResource.title = updates.title;
516
+ if (typeof updates.metadata !== 'undefined')
517
+ registeredResource.metadata = updates.metadata;
518
+ if (typeof updates.callback !== 'undefined')
519
+ registeredResource.readCallback = updates.callback;
520
+ if (typeof updates.enabled !== 'undefined')
521
+ registeredResource.enabled = updates.enabled;
522
+ this.sendResourceListChanged();
523
+ }
524
+ };
525
+ this._registeredResources[uri] = registeredResource;
526
+ return registeredResource;
527
+ }
528
+ _createRegisteredResourceTemplate(name, title, template, metadata, readCallback) {
529
+ const registeredResourceTemplate = {
530
+ resourceTemplate: template,
531
+ title,
532
+ metadata,
533
+ readCallback,
534
+ enabled: true,
535
+ disable: () => registeredResourceTemplate.update({ enabled: false }),
536
+ enable: () => registeredResourceTemplate.update({ enabled: true }),
537
+ remove: () => registeredResourceTemplate.update({ name: null }),
538
+ update: updates => {
539
+ if (typeof updates.name !== 'undefined' && updates.name !== name) {
540
+ delete this._registeredResourceTemplates[name];
541
+ if (updates.name)
542
+ this._registeredResourceTemplates[updates.name] = registeredResourceTemplate;
543
+ }
544
+ if (typeof updates.title !== 'undefined')
545
+ registeredResourceTemplate.title = updates.title;
546
+ if (typeof updates.template !== 'undefined')
547
+ registeredResourceTemplate.resourceTemplate = updates.template;
548
+ if (typeof updates.metadata !== 'undefined')
549
+ registeredResourceTemplate.metadata = updates.metadata;
550
+ if (typeof updates.callback !== 'undefined')
551
+ registeredResourceTemplate.readCallback = updates.callback;
552
+ if (typeof updates.enabled !== 'undefined')
553
+ registeredResourceTemplate.enabled = updates.enabled;
554
+ this.sendResourceListChanged();
555
+ }
556
+ };
557
+ this._registeredResourceTemplates[name] = registeredResourceTemplate;
558
+ // If the resource template has any completion callbacks, enable completions capability
559
+ const variableNames = template.uriTemplate.variableNames;
560
+ const hasCompleter = Array.isArray(variableNames) && variableNames.some(v => !!template.completeCallback(v));
561
+ if (hasCompleter) {
562
+ this.setCompletionRequestHandler();
563
+ }
564
+ return registeredResourceTemplate;
565
+ }
566
+ _createRegisteredPrompt(name, title, description, argsSchema, callback) {
567
+ const registeredPrompt = {
568
+ title,
569
+ description,
570
+ argsSchema: argsSchema === undefined ? undefined : (0, zod_compat_js_1.objectFromShape)(argsSchema),
571
+ callback,
572
+ enabled: true,
573
+ disable: () => registeredPrompt.update({ enabled: false }),
574
+ enable: () => registeredPrompt.update({ enabled: true }),
575
+ remove: () => registeredPrompt.update({ name: null }),
576
+ update: updates => {
577
+ if (typeof updates.name !== 'undefined' && updates.name !== name) {
578
+ delete this._registeredPrompts[name];
579
+ if (updates.name)
580
+ this._registeredPrompts[updates.name] = registeredPrompt;
581
+ }
582
+ if (typeof updates.title !== 'undefined')
583
+ registeredPrompt.title = updates.title;
584
+ if (typeof updates.description !== 'undefined')
585
+ registeredPrompt.description = updates.description;
586
+ if (typeof updates.argsSchema !== 'undefined')
587
+ registeredPrompt.argsSchema = (0, zod_compat_js_1.objectFromShape)(updates.argsSchema);
588
+ if (typeof updates.callback !== 'undefined')
589
+ registeredPrompt.callback = updates.callback;
590
+ if (typeof updates.enabled !== 'undefined')
591
+ registeredPrompt.enabled = updates.enabled;
592
+ this.sendPromptListChanged();
593
+ }
594
+ };
595
+ this._registeredPrompts[name] = registeredPrompt;
596
+ // If any argument uses a Completable schema, enable completions capability
597
+ if (argsSchema) {
598
+ const hasCompletable = Object.values(argsSchema).some(field => {
599
+ const inner = field instanceof zod_1.ZodOptional ? field._def?.innerType : field;
600
+ return (0, completable_js_1.isCompletable)(inner);
601
+ });
602
+ if (hasCompletable) {
603
+ this.setCompletionRequestHandler();
604
+ }
605
+ }
606
+ return registeredPrompt;
607
+ }
608
+ _createRegisteredTool(name, title, description, inputSchema, outputSchema, annotations, execution, _meta, handler) {
609
+ // Validate tool name according to SEP specification
610
+ (0, toolNameValidation_js_1.validateAndWarnToolName)(name);
611
+ const registeredTool = {
612
+ title,
613
+ description,
614
+ inputSchema: getZodSchemaObject(inputSchema),
615
+ outputSchema: getZodSchemaObject(outputSchema),
616
+ annotations,
617
+ execution,
618
+ _meta,
619
+ handler: handler,
620
+ enabled: true,
621
+ disable: () => registeredTool.update({ enabled: false }),
622
+ enable: () => registeredTool.update({ enabled: true }),
623
+ remove: () => registeredTool.update({ name: null }),
624
+ update: updates => {
625
+ if (typeof updates.name !== 'undefined' && updates.name !== name) {
626
+ if (typeof updates.name === 'string') {
627
+ (0, toolNameValidation_js_1.validateAndWarnToolName)(updates.name);
628
+ }
629
+ delete this._registeredTools[name];
630
+ if (updates.name)
631
+ this._registeredTools[updates.name] = registeredTool;
632
+ }
633
+ if (typeof updates.title !== 'undefined')
634
+ registeredTool.title = updates.title;
635
+ if (typeof updates.description !== 'undefined')
636
+ registeredTool.description = updates.description;
637
+ if (typeof updates.paramsSchema !== 'undefined')
638
+ registeredTool.inputSchema = (0, zod_compat_js_1.objectFromShape)(updates.paramsSchema);
639
+ if (typeof updates.outputSchema !== 'undefined')
640
+ registeredTool.outputSchema = (0, zod_compat_js_1.objectFromShape)(updates.outputSchema);
641
+ if (typeof updates.callback !== 'undefined')
642
+ registeredTool.handler = updates.callback;
643
+ if (typeof updates.annotations !== 'undefined')
644
+ registeredTool.annotations = updates.annotations;
645
+ if (typeof updates._meta !== 'undefined')
646
+ registeredTool._meta = updates._meta;
647
+ if (typeof updates.enabled !== 'undefined')
648
+ registeredTool.enabled = updates.enabled;
649
+ this.sendToolListChanged();
650
+ }
651
+ };
652
+ this._registeredTools[name] = registeredTool;
653
+ this.setToolRequestHandlers();
654
+ this.sendToolListChanged();
655
+ return registeredTool;
656
+ }
657
+ /**
658
+ * tool() implementation. Parses arguments passed to overrides defined above.
659
+ */
660
+ tool(name, ...rest) {
661
+ if (this._registeredTools[name]) {
662
+ throw new Error(`Tool ${name} is already registered`);
663
+ }
664
+ let description;
665
+ let inputSchema;
666
+ let outputSchema;
667
+ let annotations;
668
+ // Tool properties are passed as separate arguments, with omissions allowed.
669
+ // Support for this style is frozen as of protocol version 2025-03-26. Future additions
670
+ // to tool definition should *NOT* be added.
671
+ if (typeof rest[0] === 'string') {
672
+ description = rest.shift();
673
+ }
674
+ // Handle the different overload combinations
675
+ if (rest.length > 1) {
676
+ // We have at least one more arg before the callback
677
+ const firstArg = rest[0];
678
+ if (isZodRawShapeCompat(firstArg)) {
679
+ // We have a params schema as the first arg
680
+ inputSchema = rest.shift();
681
+ // Check if the next arg is potentially annotations
682
+ if (rest.length > 1 && typeof rest[0] === 'object' && rest[0] !== null && !isZodRawShapeCompat(rest[0])) {
683
+ // Case: tool(name, paramsSchema, annotations, cb)
684
+ // Or: tool(name, description, paramsSchema, annotations, cb)
685
+ annotations = rest.shift();
686
+ }
687
+ }
688
+ else if (typeof firstArg === 'object' && firstArg !== null) {
689
+ // Not a ZodRawShapeCompat, so must be annotations in this position
690
+ // Case: tool(name, annotations, cb)
691
+ // Or: tool(name, description, annotations, cb)
692
+ annotations = rest.shift();
693
+ }
694
+ }
695
+ const callback = rest[0];
696
+ return this._createRegisteredTool(name, undefined, description, inputSchema, outputSchema, annotations, { taskSupport: 'forbidden' }, undefined, callback);
697
+ }
698
+ /**
699
+ * Registers a tool with a config object and callback.
700
+ */
701
+ registerTool(name, config, cb) {
702
+ if (this._registeredTools[name]) {
703
+ throw new Error(`Tool ${name} is already registered`);
704
+ }
705
+ const { title, description, inputSchema, outputSchema, annotations, _meta } = config;
706
+ return this._createRegisteredTool(name, title, description, inputSchema, outputSchema, annotations, { taskSupport: 'forbidden' }, _meta, cb);
707
+ }
708
+ prompt(name, ...rest) {
709
+ if (this._registeredPrompts[name]) {
710
+ throw new Error(`Prompt ${name} is already registered`);
711
+ }
712
+ let description;
713
+ if (typeof rest[0] === 'string') {
714
+ description = rest.shift();
715
+ }
716
+ let argsSchema;
717
+ if (rest.length > 1) {
718
+ argsSchema = rest.shift();
719
+ }
720
+ const cb = rest[0];
721
+ const registeredPrompt = this._createRegisteredPrompt(name, undefined, description, argsSchema, cb);
722
+ this.setPromptRequestHandlers();
723
+ this.sendPromptListChanged();
724
+ return registeredPrompt;
725
+ }
726
+ /**
727
+ * Registers a prompt with a config object and callback.
728
+ */
729
+ registerPrompt(name, config, cb) {
730
+ if (this._registeredPrompts[name]) {
731
+ throw new Error(`Prompt ${name} is already registered`);
732
+ }
733
+ const { title, description, argsSchema } = config;
734
+ const registeredPrompt = this._createRegisteredPrompt(name, title, description, argsSchema, cb);
735
+ this.setPromptRequestHandlers();
736
+ this.sendPromptListChanged();
737
+ return registeredPrompt;
738
+ }
739
+ /**
740
+ * Checks if the server is connected to a transport.
741
+ * @returns True if the server is connected
742
+ */
743
+ isConnected() {
744
+ return this.server.transport !== undefined;
745
+ }
746
+ /**
747
+ * Sends a logging message to the client, if connected.
748
+ * Note: You only need to send the parameters object, not the entire JSON RPC message
749
+ * @see LoggingMessageNotification
750
+ * @param params
751
+ * @param sessionId optional for stateless and backward compatibility
752
+ */
753
+ async sendLoggingMessage(params, sessionId) {
754
+ return this.server.sendLoggingMessage(params, sessionId);
755
+ }
756
+ /**
757
+ * Sends a resource list changed event to the client, if connected.
758
+ */
759
+ sendResourceListChanged() {
760
+ if (this.isConnected()) {
761
+ this.server.sendResourceListChanged();
762
+ }
763
+ }
764
+ /**
765
+ * Sends a tool list changed event to the client, if connected.
766
+ */
767
+ sendToolListChanged() {
768
+ if (this.isConnected()) {
769
+ this.server.sendToolListChanged();
770
+ }
771
+ }
772
+ /**
773
+ * Sends a prompt list changed event to the client, if connected.
774
+ */
775
+ sendPromptListChanged() {
776
+ if (this.isConnected()) {
777
+ this.server.sendPromptListChanged();
778
+ }
779
+ }
780
+ }
781
+ exports.McpServer = McpServer;
782
+ /**
783
+ * A resource template combines a URI pattern with optional functionality to enumerate
784
+ * all resources matching that pattern.
785
+ */
786
+ class ResourceTemplate {
787
+ constructor(uriTemplate, _callbacks) {
788
+ this._callbacks = _callbacks;
789
+ this._uriTemplate = typeof uriTemplate === 'string' ? new uriTemplate_js_1.UriTemplate(uriTemplate) : uriTemplate;
790
+ }
791
+ /**
792
+ * Gets the URI template pattern.
793
+ */
794
+ get uriTemplate() {
795
+ return this._uriTemplate;
796
+ }
797
+ /**
798
+ * Gets the list callback, if one was provided.
799
+ */
800
+ get listCallback() {
801
+ return this._callbacks.list;
802
+ }
803
+ /**
804
+ * Gets the callback for completing a specific URI template variable, if one was provided.
805
+ */
806
+ completeCallback(variable) {
807
+ return this._callbacks.complete?.[variable];
808
+ }
809
+ }
810
+ exports.ResourceTemplate = ResourceTemplate;
811
+ const EMPTY_OBJECT_JSON_SCHEMA = {
812
+ type: 'object',
813
+ properties: {}
814
+ };
815
+ /**
816
+ * Checks if a value looks like a Zod schema by checking for parse/safeParse methods.
817
+ */
818
+ function isZodTypeLike(value) {
819
+ return (value !== null &&
820
+ typeof value === 'object' &&
821
+ 'parse' in value &&
822
+ typeof value.parse === 'function' &&
823
+ 'safeParse' in value &&
824
+ typeof value.safeParse === 'function');
825
+ }
826
+ /**
827
+ * Checks if an object is a Zod schema instance (v3 or v4).
828
+ *
829
+ * Zod schemas have internal markers:
830
+ * - v3: `_def` property
831
+ * - v4: `_zod` property
832
+ *
833
+ * This includes transformed schemas like z.preprocess(), z.transform(), z.pipe().
834
+ */
835
+ function isZodSchemaInstance(obj) {
836
+ return '_def' in obj || '_zod' in obj || isZodTypeLike(obj);
837
+ }
838
+ /**
839
+ * Checks if an object is a "raw shape" - a plain object where values are Zod schemas.
840
+ *
841
+ * Raw shapes are used as shorthand: `{ name: z.string() }` instead of `z.object({ name: z.string() })`.
842
+ *
843
+ * IMPORTANT: This must NOT match actual Zod schema instances (like z.preprocess, z.pipe),
844
+ * which have internal properties that could be mistaken for schema values.
845
+ */
846
+ function isZodRawShapeCompat(obj) {
847
+ if (typeof obj !== 'object' || obj === null) {
848
+ return false;
849
+ }
850
+ // If it's already a Zod schema instance, it's NOT a raw shape
851
+ if (isZodSchemaInstance(obj)) {
852
+ return false;
853
+ }
854
+ // Empty objects are valid raw shapes (tools with no parameters)
855
+ if (Object.keys(obj).length === 0) {
856
+ return true;
857
+ }
858
+ // A raw shape has at least one property that is a Zod schema
859
+ return Object.values(obj).some(isZodTypeLike);
860
+ }
861
+ /**
862
+ * Converts a provided Zod schema to a Zod object if it is a ZodRawShapeCompat,
863
+ * otherwise returns the schema as is.
864
+ */
865
+ function getZodSchemaObject(schema) {
866
+ if (!schema) {
867
+ return undefined;
868
+ }
869
+ if (isZodRawShapeCompat(schema)) {
870
+ return (0, zod_compat_js_1.objectFromShape)(schema);
871
+ }
872
+ return schema;
873
+ }
874
+ function promptArgumentsFromSchema(schema) {
875
+ const shape = (0, zod_compat_js_1.getObjectShape)(schema);
876
+ if (!shape)
877
+ return [];
878
+ return Object.entries(shape).map(([name, field]) => {
879
+ // Get description - works for both v3 and v4
880
+ const description = (0, zod_compat_js_1.getSchemaDescription)(field);
881
+ // Check if optional - works for both v3 and v4
882
+ const isOptional = (0, zod_compat_js_1.isSchemaOptional)(field);
883
+ return {
884
+ name,
885
+ description,
886
+ required: !isOptional
887
+ };
888
+ });
889
+ }
890
+ function getMethodValue(schema) {
891
+ const shape = (0, zod_compat_js_1.getObjectShape)(schema);
892
+ const methodSchema = shape?.method;
893
+ if (!methodSchema) {
894
+ throw new Error('Schema is missing a method literal');
895
+ }
896
+ // Extract literal value - works for both v3 and v4
897
+ const value = (0, zod_compat_js_1.getLiteralValue)(methodSchema);
898
+ if (typeof value === 'string') {
899
+ return value;
900
+ }
901
+ throw new Error('Schema method literal must be a string');
902
+ }
903
+ function createCompletionResult(suggestions) {
904
+ return {
905
+ completion: {
906
+ values: suggestions.slice(0, 100),
907
+ total: suggestions.length,
908
+ hasMore: suggestions.length > 100
909
+ }
910
+ };
911
+ }
912
+ const EMPTY_COMPLETION_RESULT = {
913
+ completion: {
914
+ values: [],
915
+ hasMore: false
916
+ }
917
+ };
918
+ //# sourceMappingURL=mcp.js.map