AbstractOptional_options: ProtocolOptionsOptionalfallbackA handler to invoke for any notification types that do not have their own handler installed.
OptionalfallbackA handler to invoke for any request types that do not have their own handler installed.
OptionaloncloseCallback for when the connection is closed for any reason.
This is invoked when close() is called as well.
OptionalonerrorCallback for when an error occurs.
Note that errors are not necessarily fatal; they are used for reporting any kind of exceptional condition out of band.
Asserts that a request handler has not already been set for the given method, in preparation for a new one being automatically installed.
Protected AbstractassertA method to check if a capability is supported by the remote side, for the given method to be called.
This should be implemented by subclasses.
Protected AbstractassertA method to check if a notification is supported by the local side, for the given method to be sent.
This should be implemented by subclasses.
Protected AbstractassertA method to check if a request handler is supported by the local side, for the given method to be handled.
This should be implemented by subclasses.
Closes the connection.
Attaches to the given transport, starts it, and starts listening for messages.
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.
Emits a notification, which is a one-way message that does not expect a response.
Optionaloptions: NotificationOptionsRemoves the notification handler for the given method.
Removes the request handler for the given method.
Sends a request and wait for a response.
Do not use this method to emit notifications! Use notification() instead.
Optionaloptions: RequestOptionsRegisters a handler to invoke when this protocol object receives a notification with the given method.
Note that this will replace any previous notification handler for the same method.
Registers a handler to invoke when this protocol object receives a request with the given method.
Note that this will replace any previous request handler for the same method.
Implements MCP protocol framing on top of a pluggable transport, including features like request/response linking, notifications, and progress.