Documentation
¶
Index ¶
Constants ¶
const ( PARSE_ERROR = -32700 INVALID_REQUEST = -32600 METHOD_NOT_FOUND = -32601 INVALID_PARAMS = -32602 INTERNAL_ERROR = -32603 )
Standard JSON-RPC error codes
const JSONRPC_VERSION = "2.0"
JSONRPC_VERSION is the version of JSON-RPC used by MCP.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type BaseMessage ¶
type BaseMessage struct {
Jsonrpc string `json:"jsonrpc"`
Method string `json:"method"`
Id RequestId `json:"id,omitempty"`
}
Generic baseMessage could either be a JSONRPCNotification or JSONRPCRequest
type Error ¶
type Error struct {
// The error type that occurred.
Code int `json:"code"`
// A short description of the error. The message SHOULD be limited
// to a concise single sentence.
Message string `json:"message"`
// Additional information about the error. The value of this member
// is defined by the sender (e.g. detailed error information, nested errors etc.).
Data interface{} `json:"data,omitempty"`
}
Error represents the error content.
type JSONRPCError ¶
type JSONRPCError struct {
Jsonrpc string `json:"jsonrpc"`
Id RequestId `json:"id"`
Error Error `json:"error"`
}
JSONRPCError represents a non-successful (error) response to a request.
type JSONRPCNotification ¶
type JSONRPCNotification struct {
Jsonrpc string `json:"jsonrpc"`
Notification
}
JSONRPCNotification represents a notification which does not expect a response.
type JSONRPCRequest ¶
type JSONRPCRequest struct {
Jsonrpc string `json:"jsonrpc"`
Id RequestId `json:"id"`
Request
Params any `json:"params,omitempty"`
}
JSONRPCRequest represents a request that expects a response.
type JSONRPCResponse ¶
type JSONRPCResponse struct {
Jsonrpc string `json:"jsonrpc"`
Id RequestId `json:"id"`
Result interface{} `json:"result"`
}
JSONRPCResponse represents a successful (non-error) response to a request.
type Notification ¶
type Notification struct {
Method string `json:"method"`
Params struct {
Meta map[string]interface{} `json:"_meta,omitempty"`
} `json:"params,omitempty"`
}
Notification is a one-way message requiring no response.
type ProgressToken ¶
type ProgressToken interface{}
ProgressToken is used to associate progress notifications with the original request.
type Request ¶
type Request struct {
Method string `json:"method"`
Params struct {
Meta struct {
// If specified, the caller is requesting out-of-band progress
// notifications for this request (as represented by
// notifications/progress). The value of this parameter is an
// opaque token that will be attached to any subsequent
// notifications. The receiver is not obligated to provide these
// notifications.
ProgressToken ProgressToken `json:"progressToken,omitempty"`
} `json:"_meta,omitempty"`
} `json:"params,omitempty"`
}
Request represents a bidirectional message with method and parameters expecting a response.