@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.
- package/LICENSE +21 -0
- package/README.md +141 -0
- package/dist/cjs/client/index.d.ts +588 -0
- package/dist/cjs/client/index.d.ts.map +1 -0
- package/dist/cjs/client/index.js +629 -0
- package/dist/cjs/client/index.js.map +1 -0
- package/dist/cjs/client/stdio.d.ts +77 -0
- package/dist/cjs/client/stdio.d.ts.map +1 -0
- package/dist/cjs/client/stdio.js +199 -0
- package/dist/cjs/client/stdio.js.map +1 -0
- package/dist/cjs/experimental/index.d.ts +13 -0
- package/dist/cjs/experimental/index.d.ts.map +1 -0
- package/dist/cjs/experimental/index.js +29 -0
- package/dist/cjs/experimental/index.js.map +1 -0
- package/dist/cjs/experimental/tasks/client.d.ts +121 -0
- package/dist/cjs/experimental/tasks/client.d.ts.map +1 -0
- package/dist/cjs/experimental/tasks/client.js +188 -0
- package/dist/cjs/experimental/tasks/client.js.map +1 -0
- package/dist/cjs/experimental/tasks/helpers.d.ts +47 -0
- package/dist/cjs/experimental/tasks/helpers.d.ts.map +1 -0
- package/dist/cjs/experimental/tasks/helpers.js +68 -0
- package/dist/cjs/experimental/tasks/helpers.js.map +1 -0
- package/dist/cjs/experimental/tasks/index.d.ts +16 -0
- package/dist/cjs/experimental/tasks/index.d.ts.map +1 -0
- package/dist/cjs/experimental/tasks/index.js +39 -0
- package/dist/cjs/experimental/tasks/index.js.map +1 -0
- package/dist/cjs/experimental/tasks/interfaces.d.ts +232 -0
- package/dist/cjs/experimental/tasks/interfaces.d.ts.map +1 -0
- package/dist/cjs/experimental/tasks/interfaces.js +19 -0
- package/dist/cjs/experimental/tasks/interfaces.js.map +1 -0
- package/dist/cjs/experimental/tasks/mcp-server.d.ts +77 -0
- package/dist/cjs/experimental/tasks/mcp-server.d.ts.map +1 -0
- package/dist/cjs/experimental/tasks/mcp-server.js +36 -0
- package/dist/cjs/experimental/tasks/mcp-server.js.map +1 -0
- package/dist/cjs/experimental/tasks/server.d.ts +170 -0
- package/dist/cjs/experimental/tasks/server.d.ts.map +1 -0
- package/dist/cjs/experimental/tasks/server.js +250 -0
- package/dist/cjs/experimental/tasks/server.js.map +1 -0
- package/dist/cjs/experimental/tasks/stores/in-memory.d.ts +94 -0
- package/dist/cjs/experimental/tasks/stores/in-memory.d.ts.map +1 -0
- package/dist/cjs/experimental/tasks/stores/in-memory.js +251 -0
- package/dist/cjs/experimental/tasks/stores/in-memory.js.map +1 -0
- package/dist/cjs/experimental/tasks/types.d.ts +10 -0
- package/dist/cjs/experimental/tasks/types.d.ts.map +1 -0
- package/dist/cjs/experimental/tasks/types.js +28 -0
- package/dist/cjs/experimental/tasks/types.js.map +1 -0
- package/dist/cjs/inMemory.d.ts +31 -0
- package/dist/cjs/inMemory.d.ts.map +1 -0
- package/dist/cjs/inMemory.js +51 -0
- package/dist/cjs/inMemory.js.map +1 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/server/completable.d.ts +38 -0
- package/dist/cjs/server/completable.d.ts.map +1 -0
- package/dist/cjs/server/completable.js +48 -0
- package/dist/cjs/server/completable.js.map +1 -0
- package/dist/cjs/server/index.d.ts +196 -0
- package/dist/cjs/server/index.d.ts.map +1 -0
- package/dist/cjs/server/index.js +444 -0
- package/dist/cjs/server/index.js.map +1 -0
- package/dist/cjs/server/mcp.d.ts +364 -0
- package/dist/cjs/server/mcp.d.ts.map +1 -0
- package/dist/cjs/server/mcp.js +918 -0
- package/dist/cjs/server/mcp.js.map +1 -0
- package/dist/cjs/server/stdio.d.ts +28 -0
- package/dist/cjs/server/stdio.d.ts.map +1 -0
- package/dist/cjs/server/stdio.js +82 -0
- package/dist/cjs/server/stdio.js.map +1 -0
- package/dist/cjs/server/zod-compat.d.ts +84 -0
- package/dist/cjs/server/zod-compat.d.ts.map +1 -0
- package/dist/cjs/server/zod-compat.js +244 -0
- package/dist/cjs/server/zod-compat.js.map +1 -0
- package/dist/cjs/server/zod-json-schema-compat.d.ts +12 -0
- package/dist/cjs/server/zod-json-schema-compat.d.ts.map +1 -0
- package/dist/cjs/server/zod-json-schema-compat.js +79 -0
- package/dist/cjs/server/zod-json-schema-compat.js.map +1 -0
- package/dist/cjs/shared/auth-info.d.ts +32 -0
- package/dist/cjs/shared/auth-info.d.ts.map +1 -0
- package/dist/cjs/shared/auth-info.js +3 -0
- package/dist/cjs/shared/auth-info.js.map +1 -0
- package/dist/cjs/shared/metadataUtils.d.ts +16 -0
- package/dist/cjs/shared/metadataUtils.d.ts.map +1 -0
- package/dist/cjs/shared/metadataUtils.js +25 -0
- package/dist/cjs/shared/metadataUtils.js.map +1 -0
- package/dist/cjs/shared/protocol.d.ts +443 -0
- package/dist/cjs/shared/protocol.d.ts.map +1 -0
- package/dist/cjs/shared/protocol.js +1104 -0
- package/dist/cjs/shared/protocol.js.map +1 -0
- package/dist/cjs/shared/responseMessage.d.ts +45 -0
- package/dist/cjs/shared/responseMessage.d.ts.map +1 -0
- package/dist/cjs/shared/responseMessage.js +23 -0
- package/dist/cjs/shared/responseMessage.js.map +1 -0
- package/dist/cjs/shared/stdio.d.ts +13 -0
- package/dist/cjs/shared/stdio.d.ts.map +1 -0
- package/dist/cjs/shared/stdio.js +37 -0
- package/dist/cjs/shared/stdio.js.map +1 -0
- package/dist/cjs/shared/toolNameValidation.d.ts +31 -0
- package/dist/cjs/shared/toolNameValidation.d.ts.map +1 -0
- package/dist/cjs/shared/toolNameValidation.js +97 -0
- package/dist/cjs/shared/toolNameValidation.js.map +1 -0
- package/dist/cjs/shared/transport.d.ts +89 -0
- package/dist/cjs/shared/transport.d.ts.map +1 -0
- package/dist/cjs/shared/transport.js +43 -0
- package/dist/cjs/shared/transport.js.map +1 -0
- package/dist/cjs/shared/uriTemplate.d.ts +25 -0
- package/dist/cjs/shared/uriTemplate.d.ts.map +1 -0
- package/dist/cjs/shared/uriTemplate.js +243 -0
- package/dist/cjs/shared/uriTemplate.js.map +1 -0
- package/dist/cjs/spec.types.d.ts +2299 -0
- package/dist/cjs/spec.types.d.ts.map +1 -0
- package/dist/cjs/spec.types.js +27 -0
- package/dist/cjs/spec.types.js.map +1 -0
- package/dist/cjs/types.d.ts +8137 -0
- package/dist/cjs/types.d.ts.map +1 -0
- package/dist/cjs/types.js +2092 -0
- package/dist/cjs/types.js.map +1 -0
- package/dist/cjs/validation/ajv-provider.d.ts +53 -0
- package/dist/cjs/validation/ajv-provider.d.ts.map +1 -0
- package/dist/cjs/validation/ajv-provider.js +94 -0
- package/dist/cjs/validation/ajv-provider.js.map +1 -0
- package/dist/cjs/validation/cfworker-provider.d.ts +51 -0
- package/dist/cjs/validation/cfworker-provider.d.ts.map +1 -0
- package/dist/cjs/validation/cfworker-provider.js +69 -0
- package/dist/cjs/validation/cfworker-provider.js.map +1 -0
- package/dist/cjs/validation/index.d.ts +29 -0
- package/dist/cjs/validation/index.d.ts.map +1 -0
- package/dist/cjs/validation/index.js +30 -0
- package/dist/cjs/validation/index.js.map +1 -0
- package/dist/cjs/validation/types.d.ts +65 -0
- package/dist/cjs/validation/types.d.ts.map +1 -0
- package/dist/cjs/validation/types.js +3 -0
- package/dist/cjs/validation/types.js.map +1 -0
- package/dist/esm/client/index.d.ts +588 -0
- package/dist/esm/client/index.d.ts.map +1 -0
- package/dist/esm/client/index.js +624 -0
- package/dist/esm/client/index.js.map +1 -0
- package/dist/esm/client/stdio.d.ts +77 -0
- package/dist/esm/client/stdio.d.ts.map +1 -0
- package/dist/esm/client/stdio.js +191 -0
- package/dist/esm/client/stdio.js.map +1 -0
- package/dist/esm/experimental/index.d.ts +13 -0
- package/dist/esm/experimental/index.d.ts.map +1 -0
- package/dist/esm/experimental/index.js +13 -0
- package/dist/esm/experimental/index.js.map +1 -0
- package/dist/esm/experimental/tasks/client.d.ts +121 -0
- package/dist/esm/experimental/tasks/client.d.ts.map +1 -0
- package/dist/esm/experimental/tasks/client.js +184 -0
- package/dist/esm/experimental/tasks/client.js.map +1 -0
- package/dist/esm/experimental/tasks/helpers.d.ts +47 -0
- package/dist/esm/experimental/tasks/helpers.d.ts.map +1 -0
- package/dist/esm/experimental/tasks/helpers.js +64 -0
- package/dist/esm/experimental/tasks/helpers.js.map +1 -0
- package/dist/esm/experimental/tasks/index.d.ts +16 -0
- package/dist/esm/experimental/tasks/index.d.ts.map +1 -0
- package/dist/esm/experimental/tasks/index.js +20 -0
- package/dist/esm/experimental/tasks/index.js.map +1 -0
- package/dist/esm/experimental/tasks/interfaces.d.ts +232 -0
- package/dist/esm/experimental/tasks/interfaces.d.ts.map +1 -0
- package/dist/esm/experimental/tasks/interfaces.js +16 -0
- package/dist/esm/experimental/tasks/interfaces.js.map +1 -0
- package/dist/esm/experimental/tasks/mcp-server.d.ts +77 -0
- package/dist/esm/experimental/tasks/mcp-server.d.ts.map +1 -0
- package/dist/esm/experimental/tasks/mcp-server.js +32 -0
- package/dist/esm/experimental/tasks/mcp-server.js.map +1 -0
- package/dist/esm/experimental/tasks/server.d.ts +170 -0
- package/dist/esm/experimental/tasks/server.d.ts.map +1 -0
- package/dist/esm/experimental/tasks/server.js +246 -0
- package/dist/esm/experimental/tasks/server.js.map +1 -0
- package/dist/esm/experimental/tasks/stores/in-memory.d.ts +94 -0
- package/dist/esm/experimental/tasks/stores/in-memory.d.ts.map +1 -0
- package/dist/esm/experimental/tasks/stores/in-memory.js +246 -0
- package/dist/esm/experimental/tasks/stores/in-memory.js.map +1 -0
- package/dist/esm/experimental/tasks/types.d.ts +10 -0
- package/dist/esm/experimental/tasks/types.d.ts.map +1 -0
- package/dist/esm/experimental/tasks/types.js +10 -0
- package/dist/esm/experimental/tasks/types.js.map +1 -0
- package/dist/esm/inMemory.d.ts +31 -0
- package/dist/esm/inMemory.d.ts.map +1 -0
- package/dist/esm/inMemory.js +47 -0
- package/dist/esm/inMemory.js.map +1 -0
- package/dist/esm/package.json +1 -0
- package/dist/esm/server/completable.d.ts +38 -0
- package/dist/esm/server/completable.d.ts.map +1 -0
- package/dist/esm/server/completable.js +41 -0
- package/dist/esm/server/completable.js.map +1 -0
- package/dist/esm/server/index.d.ts +196 -0
- package/dist/esm/server/index.d.ts.map +1 -0
- package/dist/esm/server/index.js +440 -0
- package/dist/esm/server/index.js.map +1 -0
- package/dist/esm/server/mcp.d.ts +364 -0
- package/dist/esm/server/mcp.d.ts.map +1 -0
- package/dist/esm/server/mcp.js +913 -0
- package/dist/esm/server/mcp.js.map +1 -0
- package/dist/esm/server/stdio.d.ts +28 -0
- package/dist/esm/server/stdio.d.ts.map +1 -0
- package/dist/esm/server/stdio.js +75 -0
- package/dist/esm/server/stdio.js.map +1 -0
- package/dist/esm/server/zod-compat.d.ts +84 -0
- package/dist/esm/server/zod-compat.d.ts.map +1 -0
- package/dist/esm/server/zod-compat.js +209 -0
- package/dist/esm/server/zod-compat.js.map +1 -0
- package/dist/esm/server/zod-json-schema-compat.d.ts +12 -0
- package/dist/esm/server/zod-json-schema-compat.d.ts.map +1 -0
- package/dist/esm/server/zod-json-schema-compat.js +51 -0
- package/dist/esm/server/zod-json-schema-compat.js.map +1 -0
- package/dist/esm/shared/auth-info.d.ts +32 -0
- package/dist/esm/shared/auth-info.d.ts.map +1 -0
- package/dist/esm/shared/auth-info.js +2 -0
- package/dist/esm/shared/auth-info.js.map +1 -0
- package/dist/esm/shared/metadataUtils.d.ts +16 -0
- package/dist/esm/shared/metadataUtils.d.ts.map +1 -0
- package/dist/esm/shared/metadataUtils.js +22 -0
- package/dist/esm/shared/metadataUtils.js.map +1 -0
- package/dist/esm/shared/protocol.d.ts +443 -0
- package/dist/esm/shared/protocol.d.ts.map +1 -0
- package/dist/esm/shared/protocol.js +1099 -0
- package/dist/esm/shared/protocol.js.map +1 -0
- package/dist/esm/shared/responseMessage.d.ts +45 -0
- package/dist/esm/shared/responseMessage.d.ts.map +1 -0
- package/dist/esm/shared/responseMessage.js +19 -0
- package/dist/esm/shared/responseMessage.js.map +1 -0
- package/dist/esm/shared/stdio.d.ts +13 -0
- package/dist/esm/shared/stdio.d.ts.map +1 -0
- package/dist/esm/shared/stdio.js +31 -0
- package/dist/esm/shared/stdio.js.map +1 -0
- package/dist/esm/shared/toolNameValidation.d.ts +31 -0
- package/dist/esm/shared/toolNameValidation.d.ts.map +1 -0
- package/dist/esm/shared/toolNameValidation.js +92 -0
- package/dist/esm/shared/toolNameValidation.js.map +1 -0
- package/dist/esm/shared/transport.d.ts +89 -0
- package/dist/esm/shared/transport.d.ts.map +1 -0
- package/dist/esm/shared/transport.js +39 -0
- package/dist/esm/shared/transport.js.map +1 -0
- package/dist/esm/shared/uriTemplate.d.ts +25 -0
- package/dist/esm/shared/uriTemplate.d.ts.map +1 -0
- package/dist/esm/shared/uriTemplate.js +239 -0
- package/dist/esm/shared/uriTemplate.js.map +1 -0
- package/dist/esm/spec.types.d.ts +2299 -0
- package/dist/esm/spec.types.d.ts.map +1 -0
- package/dist/esm/spec.types.js +24 -0
- package/dist/esm/spec.types.js.map +1 -0
- package/dist/esm/types.d.ts +8137 -0
- package/dist/esm/types.d.ts.map +1 -0
- package/dist/esm/types.js +2052 -0
- package/dist/esm/types.js.map +1 -0
- package/dist/esm/validation/ajv-provider.d.ts +53 -0
- package/dist/esm/validation/ajv-provider.d.ts.map +1 -0
- package/dist/esm/validation/ajv-provider.js +87 -0
- package/dist/esm/validation/ajv-provider.js.map +1 -0
- package/dist/esm/validation/cfworker-provider.d.ts +51 -0
- package/dist/esm/validation/cfworker-provider.d.ts.map +1 -0
- package/dist/esm/validation/cfworker-provider.js +65 -0
- package/dist/esm/validation/cfworker-provider.js.map +1 -0
- package/dist/esm/validation/index.d.ts +29 -0
- package/dist/esm/validation/index.d.ts.map +1 -0
- package/dist/esm/validation/index.js +29 -0
- package/dist/esm/validation/index.js.map +1 -0
- package/dist/esm/validation/types.d.ts +65 -0
- package/dist/esm/validation/types.d.ts.map +1 -0
- package/dist/esm/validation/types.js +2 -0
- package/dist/esm/validation/types.js.map +1 -0
- package/package.json +124 -0
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Utilities for working with BaseMetadata objects.
|
|
3
|
+
*/
|
|
4
|
+
/**
|
|
5
|
+
* Gets the display name for an object with BaseMetadata.
|
|
6
|
+
* For tools, the precedence is: title → annotations.title → name
|
|
7
|
+
* For other objects: title → name
|
|
8
|
+
* This implements the spec requirement: "if no title is provided, name should be used for display purposes"
|
|
9
|
+
*/
|
|
10
|
+
export function getDisplayName(metadata) {
|
|
11
|
+
// First check for title (not undefined and not empty string)
|
|
12
|
+
if (metadata.title !== undefined && metadata.title !== '') {
|
|
13
|
+
return metadata.title;
|
|
14
|
+
}
|
|
15
|
+
// Then check for annotations.title (only present in Tool objects)
|
|
16
|
+
if ('annotations' in metadata && metadata.annotations?.title) {
|
|
17
|
+
return metadata.annotations.title;
|
|
18
|
+
}
|
|
19
|
+
// Finally fall back to name
|
|
20
|
+
return metadata.name;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=metadataUtils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadataUtils.js","sourceRoot":"","sources":["../../../src/shared/metadataUtils.ts"],"names":[],"mappings":"AAEA;;GAEG;AAEH;;;;;GAKG;AACH,MAAM,UAAU,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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"}
|