@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,32 @@
1
+ /**
2
+ * Information about a validated access token, provided to request handlers.
3
+ */
4
+ export interface AuthInfo {
5
+ /**
6
+ * The access token.
7
+ */
8
+ token: string;
9
+ /**
10
+ * The client ID associated with this token.
11
+ */
12
+ clientId: string;
13
+ /**
14
+ * Scopes associated with this token.
15
+ */
16
+ scopes: string[];
17
+ /**
18
+ * When the token expires (in seconds since epoch).
19
+ */
20
+ expiresAt?: number;
21
+ /**
22
+ * The RFC 8707 resource server identifier for which this token is valid.
23
+ * If set, this MUST match the MCP server's resource identifier (minus hash fragment).
24
+ */
25
+ resource?: URL;
26
+ /**
27
+ * Additional data associated with the token.
28
+ * This field should be used for any additional data that needs to be attached to the auth info.
29
+ */
30
+ extra?: Record<string, unknown>;
31
+ }
32
+ //# sourceMappingURL=auth-info.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-info.d.ts","sourceRoot":"","sources":["../../../src/shared/auth-info.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,WAAW,QAAQ;IACvB;;OAEG;IACH,KAAK,EAAE,MAAM,CAAC;IAEd;;OAEG;IACH,QAAQ,EAAE,MAAM,CAAC;IAEjB;;OAEG;IACH,MAAM,EAAE,MAAM,EAAE,CAAC;IAEjB;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB;;;OAGG;IACH,QAAQ,CAAC,EAAE,GAAG,CAAC;IAEf;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACjC"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=auth-info.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-info.js","sourceRoot":"","sources":["../../../src/shared/auth-info.ts"],"names":[],"mappings":""}
@@ -0,0 +1,16 @@
1
+ import { BaseMetadata } from '../types.js';
2
+ /**
3
+ * Utilities for working with BaseMetadata objects.
4
+ */
5
+ /**
6
+ * Gets the display name for an object with BaseMetadata.
7
+ * For tools, the precedence is: title → annotations.title → name
8
+ * For other objects: title → name
9
+ * This implements the spec requirement: "if no title is provided, name should be used for display purposes"
10
+ */
11
+ export declare function getDisplayName(metadata: BaseMetadata | (BaseMetadata & {
12
+ annotations?: {
13
+ title?: string;
14
+ };
15
+ })): string;
16
+ //# sourceMappingURL=metadataUtils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"metadataUtils.d.ts","sourceRoot":"","sources":["../../../src/shared/metadataUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C;;GAEG;AAEH;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,QAAQ,EAAE,YAAY,GAAG,CAAC,YAAY,GAAG;IAAE,WAAW,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE,CAAC,GAAG,MAAM,CAarH"}
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getDisplayName = getDisplayName;
4
+ /**
5
+ * Utilities for working with BaseMetadata objects.
6
+ */
7
+ /**
8
+ * Gets the display name for an object with BaseMetadata.
9
+ * For tools, the precedence is: title → annotations.title → name
10
+ * For other objects: title → name
11
+ * This implements the spec requirement: "if no title is provided, name should be used for display purposes"
12
+ */
13
+ function getDisplayName(metadata) {
14
+ // First check for title (not undefined and not empty string)
15
+ if (metadata.title !== undefined && metadata.title !== '') {
16
+ return metadata.title;
17
+ }
18
+ // Then check for annotations.title (only present in Tool objects)
19
+ if ('annotations' in metadata && metadata.annotations?.title) {
20
+ return metadata.annotations.title;
21
+ }
22
+ // Finally fall back to name
23
+ return metadata.name;
24
+ }
25
+ //# sourceMappingURL=metadataUtils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"metadataUtils.js","sourceRoot":"","sources":["../../../src/shared/metadataUtils.ts"],"names":[],"mappings":";;AAYA,wCAaC;AAvBD;;GAEG;AAEH;;;;;GAKG;AACH,SAAgB,cAAc,CAAC,QAA8E;IACzG,6DAA6D;IAC7D,IAAI,QAAQ,CAAC,KAAK,KAAK,SAAS,IAAI,QAAQ,CAAC,KAAK,KAAK,EAAE,EAAE,CAAC;QACxD,OAAO,QAAQ,CAAC,KAAK,CAAC;IAC1B,CAAC;IAED,kEAAkE;IAClE,IAAI,aAAa,IAAI,QAAQ,IAAI,QAAQ,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC;QAC3D,OAAO,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC;IACtC,CAAC;IAED,4BAA4B;IAC5B,OAAO,QAAQ,CAAC,IAAI,CAAC;AACzB,CAAC"}
@@ -0,0 +1,443 @@
1
+ import { AnySchema, AnyObjectSchema, SchemaOutput } from '../server/zod-compat.js';
2
+ import { ClientCapabilities, GetTaskRequest, GetTaskPayloadRequest, ListTasksResultSchema, CancelTaskResultSchema, JSONRPCRequest, Progress, RequestId, Result, ServerCapabilities, RequestMeta, RequestInfo, GetTaskResult, TaskCreationParams, RelatedTaskMetadata, Task, Request, Notification } from '../types.js';
3
+ import { Transport, TransportSendOptions } from './transport.js';
4
+ import { AuthInfo } from './auth-info.js';
5
+ import { TaskStore, TaskMessageQueue, CreateTaskOptions } from '../experimental/tasks/interfaces.js';
6
+ import { ResponseMessage } from './responseMessage.js';
7
+ /**
8
+ * Callback for progress notifications.
9
+ */
10
+ export type ProgressCallback = (progress: Progress) => void;
11
+ /**
12
+ * Additional initialization options.
13
+ */
14
+ export type ProtocolOptions = {
15
+ /**
16
+ * Whether to restrict emitted requests to only those that the remote side has indicated that they can handle, through their advertised capabilities.
17
+ *
18
+ * Note that this DOES NOT affect checking of _local_ side capabilities, as it is considered a logic error to mis-specify those.
19
+ *
20
+ * Currently this defaults to false, for backwards compatibility with SDK versions that did not advertise capabilities correctly. In future, this will default to true.
21
+ */
22
+ enforceStrictCapabilities?: boolean;
23
+ /**
24
+ * An array of notification method names that should be automatically debounced.
25
+ * Any notifications with a method in this list will be coalesced if they
26
+ * occur in the same tick of the event loop.
27
+ * e.g., ['notifications/tools/list_changed']
28
+ */
29
+ debouncedNotificationMethods?: string[];
30
+ /**
31
+ * Optional task storage implementation. If provided, enables task-related request handlers
32
+ * and provides task storage capabilities to request handlers.
33
+ */
34
+ taskStore?: TaskStore;
35
+ /**
36
+ * Optional task message queue implementation for managing server-initiated messages
37
+ * that will be delivered through the tasks/result response stream.
38
+ */
39
+ taskMessageQueue?: TaskMessageQueue;
40
+ /**
41
+ * Default polling interval (in milliseconds) for task status checks when no pollInterval
42
+ * is provided by the server. Defaults to 5000ms if not specified.
43
+ */
44
+ defaultTaskPollInterval?: number;
45
+ /**
46
+ * Maximum number of messages that can be queued per task for side-channel delivery.
47
+ * If undefined, the queue size is unbounded.
48
+ * When the limit is exceeded, the TaskMessageQueue implementation's enqueue() method
49
+ * will throw an error. It's the implementation's responsibility to handle overflow
50
+ * appropriately (e.g., by failing the task, dropping messages, etc.).
51
+ */
52
+ maxTaskQueueSize?: number;
53
+ };
54
+ /**
55
+ * The default request timeout, in miliseconds.
56
+ */
57
+ export declare const DEFAULT_REQUEST_TIMEOUT_MSEC = 60000;
58
+ /**
59
+ * Options that can be given per request.
60
+ */
61
+ export type RequestOptions = {
62
+ /**
63
+ * If set, requests progress notifications from the remote end (if supported). When progress notifications are received, this callback will be invoked.
64
+ *
65
+ * For task-augmented requests: progress notifications continue after CreateTaskResult is returned and stop automatically when the task reaches a terminal status.
66
+ */
67
+ onprogress?: ProgressCallback;
68
+ /**
69
+ * Can be used to cancel an in-flight request. This will cause an AbortError to be raised from request().
70
+ */
71
+ signal?: AbortSignal;
72
+ /**
73
+ * A timeout (in milliseconds) for this request. If exceeded, an McpError with code `RequestTimeout` will be raised from request().
74
+ *
75
+ * If not specified, `DEFAULT_REQUEST_TIMEOUT_MSEC` will be used as the timeout.
76
+ */
77
+ timeout?: number;
78
+ /**
79
+ * If true, receiving a progress notification will reset the request timeout.
80
+ * This is useful for long-running operations that send periodic progress updates.
81
+ * Default: false
82
+ */
83
+ resetTimeoutOnProgress?: boolean;
84
+ /**
85
+ * Maximum total time (in milliseconds) to wait for a response.
86
+ * If exceeded, an McpError with code `RequestTimeout` will be raised, regardless of progress notifications.
87
+ * If not specified, there is no maximum total timeout.
88
+ */
89
+ maxTotalTimeout?: number;
90
+ /**
91
+ * If provided, augments the request with task creation parameters to enable call-now, fetch-later execution patterns.
92
+ */
93
+ task?: TaskCreationParams;
94
+ /**
95
+ * If provided, associates this request with a related task.
96
+ */
97
+ relatedTask?: RelatedTaskMetadata;
98
+ } & TransportSendOptions;
99
+ /**
100
+ * Options that can be given per notification.
101
+ */
102
+ export type NotificationOptions = {
103
+ /**
104
+ * May be used to indicate to the transport which incoming request to associate this outgoing notification with.
105
+ */
106
+ relatedRequestId?: RequestId;
107
+ /**
108
+ * If provided, associates this notification with a related task.
109
+ */
110
+ relatedTask?: RelatedTaskMetadata;
111
+ };
112
+ /**
113
+ * Options that can be given per request.
114
+ */
115
+ export type TaskRequestOptions = Omit<RequestOptions, 'relatedTask'>;
116
+ /**
117
+ * Request-scoped TaskStore interface.
118
+ */
119
+ export interface RequestTaskStore {
120
+ /**
121
+ * Creates a new task with the given creation parameters.
122
+ * The implementation generates a unique taskId and createdAt timestamp.
123
+ *
124
+ * @param taskParams - The task creation parameters from the request
125
+ * @returns The created task object
126
+ */
127
+ createTask(taskParams: CreateTaskOptions): Promise<Task>;
128
+ /**
129
+ * Gets the current status of a task.
130
+ *
131
+ * @param taskId - The task identifier
132
+ * @returns The task object
133
+ * @throws If the task does not exist
134
+ */
135
+ getTask(taskId: string): Promise<Task>;
136
+ /**
137
+ * Stores the result of a task and sets its final status.
138
+ *
139
+ * @param taskId - The task identifier
140
+ * @param status - The final status: 'completed' for success, 'failed' for errors
141
+ * @param result - The result to store
142
+ */
143
+ storeTaskResult(taskId: string, status: 'completed' | 'failed', result: Result): Promise<void>;
144
+ /**
145
+ * Retrieves the stored result of a task.
146
+ *
147
+ * @param taskId - The task identifier
148
+ * @returns The stored result
149
+ */
150
+ getTaskResult(taskId: string): Promise<Result>;
151
+ /**
152
+ * Updates a task's status (e.g., to 'cancelled', 'failed', 'completed').
153
+ *
154
+ * @param taskId - The task identifier
155
+ * @param status - The new status
156
+ * @param statusMessage - Optional diagnostic message for failed tasks or other status information
157
+ */
158
+ updateTaskStatus(taskId: string, status: Task['status'], statusMessage?: string): Promise<void>;
159
+ /**
160
+ * Lists tasks, optionally starting from a pagination cursor.
161
+ *
162
+ * @param cursor - Optional cursor for pagination
163
+ * @returns An object containing the tasks array and an optional nextCursor
164
+ */
165
+ listTasks(cursor?: string): Promise<{
166
+ tasks: Task[];
167
+ nextCursor?: string;
168
+ }>;
169
+ }
170
+ /**
171
+ * Extra data given to request handlers.
172
+ */
173
+ export type RequestHandlerExtra<SendRequestT extends Request, SendNotificationT extends Notification> = {
174
+ /**
175
+ * An abort signal used to communicate if the request was cancelled from the sender's side.
176
+ */
177
+ signal: AbortSignal;
178
+ /**
179
+ * Information about a validated access token, provided to request handlers.
180
+ */
181
+ authInfo?: AuthInfo;
182
+ /**
183
+ * The session ID from the transport, if available.
184
+ */
185
+ sessionId?: string;
186
+ /**
187
+ * Metadata from the original request.
188
+ */
189
+ _meta?: RequestMeta;
190
+ /**
191
+ * The JSON-RPC ID of the request being handled.
192
+ * This can be useful for tracking or logging purposes.
193
+ */
194
+ requestId: RequestId;
195
+ taskId?: string;
196
+ taskStore?: RequestTaskStore;
197
+ taskRequestedTtl?: number | null;
198
+ /**
199
+ * The original HTTP request.
200
+ */
201
+ requestInfo?: RequestInfo;
202
+ /**
203
+ * Sends a notification that relates to the current request being handled.
204
+ *
205
+ * This is used by certain transports to correctly associate related messages.
206
+ */
207
+ sendNotification: (notification: SendNotificationT) => Promise<void>;
208
+ /**
209
+ * Sends a request that relates to the current request being handled.
210
+ *
211
+ * This is used by certain transports to correctly associate related messages.
212
+ */
213
+ sendRequest: <U extends AnySchema>(request: SendRequestT, resultSchema: U, options?: TaskRequestOptions) => Promise<SchemaOutput<U>>;
214
+ /**
215
+ * Closes the SSE stream for this request, triggering client reconnection.
216
+ * Only available when using StreamableHTTPServerTransport with eventStore configured.
217
+ * Use this to implement polling behavior during long-running operations.
218
+ */
219
+ closeSSEStream?: () => void;
220
+ /**
221
+ * Closes the standalone GET SSE stream, triggering client reconnection.
222
+ * Only available when using StreamableHTTPServerTransport with eventStore configured.
223
+ * Use this to implement polling behavior for server-initiated notifications.
224
+ */
225
+ closeStandaloneSSEStream?: () => void;
226
+ };
227
+ /**
228
+ * Implements MCP protocol framing on top of a pluggable transport, including
229
+ * features like request/response linking, notifications, and progress.
230
+ */
231
+ export declare abstract class Protocol<SendRequestT extends Request, SendNotificationT extends Notification, SendResultT extends Result> {
232
+ private _options?;
233
+ private _transport?;
234
+ private _requestMessageId;
235
+ private _requestHandlers;
236
+ private _requestHandlerAbortControllers;
237
+ private _notificationHandlers;
238
+ private _responseHandlers;
239
+ private _progressHandlers;
240
+ private _timeoutInfo;
241
+ private _pendingDebouncedNotifications;
242
+ private _taskProgressTokens;
243
+ private _taskStore?;
244
+ private _taskMessageQueue?;
245
+ private _requestResolvers;
246
+ /**
247
+ * Callback for when the connection is closed for any reason.
248
+ *
249
+ * This is invoked when close() is called as well.
250
+ */
251
+ onclose?: () => void;
252
+ /**
253
+ * Callback for when an error occurs.
254
+ *
255
+ * Note that errors are not necessarily fatal; they are used for reporting any kind of exceptional condition out of band.
256
+ */
257
+ onerror?: (error: Error) => void;
258
+ /**
259
+ * A handler to invoke for any request types that do not have their own handler installed.
260
+ */
261
+ fallbackRequestHandler?: (request: JSONRPCRequest, extra: RequestHandlerExtra<SendRequestT, SendNotificationT>) => Promise<SendResultT>;
262
+ /**
263
+ * A handler to invoke for any notification types that do not have their own handler installed.
264
+ */
265
+ fallbackNotificationHandler?: (notification: Notification) => Promise<void>;
266
+ constructor(_options?: ProtocolOptions | undefined);
267
+ private _oncancel;
268
+ private _setupTimeout;
269
+ private _resetTimeout;
270
+ private _cleanupTimeout;
271
+ /**
272
+ * Attaches to the given transport, starts it, and starts listening for messages.
273
+ *
274
+ * The Protocol 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.
275
+ */
276
+ connect(transport: Transport): Promise<void>;
277
+ private _onclose;
278
+ private _onerror;
279
+ private _onnotification;
280
+ private _onrequest;
281
+ private _onprogress;
282
+ private _onresponse;
283
+ get transport(): Transport | undefined;
284
+ /**
285
+ * Closes the connection.
286
+ */
287
+ close(): Promise<void>;
288
+ /**
289
+ * A method to check if a capability is supported by the remote side, for the given method to be called.
290
+ *
291
+ * This should be implemented by subclasses.
292
+ */
293
+ protected abstract assertCapabilityForMethod(method: SendRequestT['method']): void;
294
+ /**
295
+ * A method to check if a notification is supported by the local side, for the given method to be sent.
296
+ *
297
+ * This should be implemented by subclasses.
298
+ */
299
+ protected abstract assertNotificationCapability(method: SendNotificationT['method']): void;
300
+ /**
301
+ * A method to check if a request handler is supported by the local side, for the given method to be handled.
302
+ *
303
+ * This should be implemented by subclasses.
304
+ */
305
+ protected abstract assertRequestHandlerCapability(method: string): void;
306
+ /**
307
+ * A method to check if task creation is supported for the given request method.
308
+ *
309
+ * This should be implemented by subclasses.
310
+ */
311
+ protected abstract assertTaskCapability(method: string): void;
312
+ /**
313
+ * A method to check if task handler is supported by the local side, for the given method to be handled.
314
+ *
315
+ * This should be implemented by subclasses.
316
+ */
317
+ protected abstract assertTaskHandlerCapability(method: string): void;
318
+ /**
319
+ * Sends a request and returns an AsyncGenerator that yields response messages.
320
+ * The generator is guaranteed to end with either a 'result' or 'error' message.
321
+ *
322
+ * @example
323
+ * ```typescript
324
+ * const stream = protocol.requestStream(request, resultSchema, options);
325
+ * for await (const message of stream) {
326
+ * switch (message.type) {
327
+ * case 'taskCreated':
328
+ * console.log('Task created:', message.task.taskId);
329
+ * break;
330
+ * case 'taskStatus':
331
+ * console.log('Task status:', message.task.status);
332
+ * break;
333
+ * case 'result':
334
+ * console.log('Final result:', message.result);
335
+ * break;
336
+ * case 'error':
337
+ * console.error('Error:', message.error);
338
+ * break;
339
+ * }
340
+ * }
341
+ * ```
342
+ *
343
+ * @experimental Use `client.experimental.tasks.requestStream()` to access this method.
344
+ */
345
+ protected requestStream<T extends AnySchema>(request: SendRequestT, resultSchema: T, options?: RequestOptions): AsyncGenerator<ResponseMessage<SchemaOutput<T>>, void, void>;
346
+ /**
347
+ * Sends a request and waits for a response.
348
+ *
349
+ * Do not use this method to emit notifications! Use notification() instead.
350
+ */
351
+ request<T extends AnySchema>(request: SendRequestT, resultSchema: T, options?: RequestOptions): Promise<SchemaOutput<T>>;
352
+ /**
353
+ * Gets the current status of a task.
354
+ *
355
+ * @experimental Use `client.experimental.tasks.getTask()` to access this method.
356
+ */
357
+ protected getTask(params: GetTaskRequest['params'], options?: RequestOptions): Promise<GetTaskResult>;
358
+ /**
359
+ * Retrieves the result of a completed task.
360
+ *
361
+ * @experimental Use `client.experimental.tasks.getTaskResult()` to access this method.
362
+ */
363
+ protected getTaskResult<T extends AnySchema>(params: GetTaskPayloadRequest['params'], resultSchema: T, options?: RequestOptions): Promise<SchemaOutput<T>>;
364
+ /**
365
+ * Lists tasks, optionally starting from a pagination cursor.
366
+ *
367
+ * @experimental Use `client.experimental.tasks.listTasks()` to access this method.
368
+ */
369
+ protected listTasks(params?: {
370
+ cursor?: string;
371
+ }, options?: RequestOptions): Promise<SchemaOutput<typeof ListTasksResultSchema>>;
372
+ /**
373
+ * Cancels a specific task.
374
+ *
375
+ * @experimental Use `client.experimental.tasks.cancelTask()` to access this method.
376
+ */
377
+ protected cancelTask(params: {
378
+ taskId: string;
379
+ }, options?: RequestOptions): Promise<SchemaOutput<typeof CancelTaskResultSchema>>;
380
+ /**
381
+ * Emits a notification, which is a one-way message that does not expect a response.
382
+ */
383
+ notification(notification: SendNotificationT, options?: NotificationOptions): Promise<void>;
384
+ /**
385
+ * Registers a handler to invoke when this protocol object receives a request with the given method.
386
+ *
387
+ * Note that this will replace any previous request handler for the same method.
388
+ */
389
+ setRequestHandler<T extends AnyObjectSchema>(requestSchema: T, handler: (request: SchemaOutput<T>, extra: RequestHandlerExtra<SendRequestT, SendNotificationT>) => SendResultT | Promise<SendResultT>): void;
390
+ /**
391
+ * Removes the request handler for the given method.
392
+ */
393
+ removeRequestHandler(method: string): void;
394
+ /**
395
+ * Asserts that a request handler has not already been set for the given method, in preparation for a new one being automatically installed.
396
+ */
397
+ assertCanSetRequestHandler(method: string): void;
398
+ /**
399
+ * Registers a handler to invoke when this protocol object receives a notification with the given method.
400
+ *
401
+ * Note that this will replace any previous notification handler for the same method.
402
+ */
403
+ setNotificationHandler<T extends AnyObjectSchema>(notificationSchema: T, handler: (notification: SchemaOutput<T>) => void | Promise<void>): void;
404
+ /**
405
+ * Removes the notification handler for the given method.
406
+ */
407
+ removeNotificationHandler(method: string): void;
408
+ /**
409
+ * Cleans up the progress handler associated with a task.
410
+ * This should be called when a task reaches a terminal status.
411
+ */
412
+ private _cleanupTaskProgressHandler;
413
+ /**
414
+ * Enqueues a task-related message for side-channel delivery via tasks/result.
415
+ * @param taskId The task ID to associate the message with
416
+ * @param message The message to enqueue
417
+ * @param sessionId Optional session ID for binding the operation to a specific session
418
+ * @throws Error if taskStore is not configured or if enqueue fails (e.g., queue overflow)
419
+ *
420
+ * Note: If enqueue fails, it's the TaskMessageQueue implementation's responsibility to handle
421
+ * the error appropriately (e.g., by failing the task, logging, etc.). The Protocol layer
422
+ * simply propagates the error.
423
+ */
424
+ private _enqueueTaskMessage;
425
+ /**
426
+ * Clears the message queue for a task and rejects any pending request resolvers.
427
+ * @param taskId The task ID whose queue should be cleared
428
+ * @param sessionId Optional session ID for binding the operation to a specific session
429
+ */
430
+ private _clearTaskQueue;
431
+ /**
432
+ * Waits for a task update (new messages or status change) with abort signal support.
433
+ * Uses polling to check for updates at the task's configured poll interval.
434
+ * @param taskId The task ID to wait for
435
+ * @param signal Abort signal to cancel the wait
436
+ * @returns Promise that resolves when an update occurs or rejects if aborted
437
+ */
438
+ private _waitForTaskUpdate;
439
+ private requestTaskStore;
440
+ }
441
+ export declare function mergeCapabilities(base: ServerCapabilities, additional: Partial<ServerCapabilities>): ServerCapabilities;
442
+ export declare function mergeCapabilities(base: ClientCapabilities, additional: Partial<ClientCapabilities>): ClientCapabilities;
443
+ //# sourceMappingURL=protocol.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"protocol.d.ts","sourceRoot":"","sources":["../../../src/shared/protocol.ts"],"names":[],"mappings":"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"}