Skip to content

message

Message wrapper with metadata support.

This module defines a wrapper type that combines JSONRPCMessage with metadata to support transport-specific features like resumability.

ClientMessageMetadata dataclass

Metadata specific to client messages.

Source code in src/mcp/shared/message.py
21
22
23
24
25
26
@dataclass
class ClientMessageMetadata:
    """Metadata specific to client messages."""

    resumption_token: ResumptionToken | None = None
    on_resumption_token_update: Callable[[ResumptionToken], Awaitable[None]] | None = None

ServerMessageMetadata dataclass

Metadata specific to server messages.

Source code in src/mcp/shared/message.py
29
30
31
32
33
34
35
36
37
38
39
40
41
@dataclass
class ServerMessageMetadata:
    """Metadata specific to server messages."""

    related_request_id: RequestId | None = None
    # Transport-specific request context (e.g. starlette Request for HTTP
    # transports, None for stdio). Typed as Any because the server layer is
    # transport-agnostic.
    request_context: Any = None
    # Callback to close SSE stream for the current request without terminating
    close_sse_stream: CloseSSEStreamCallback | None = None
    # Callback to close the standalone GET SSE stream (for unsolicited notifications)
    close_standalone_sse_stream: CloseSSEStreamCallback | None = None

SessionMessage dataclass

A message with specific metadata for transport-specific features.

Source code in src/mcp/shared/message.py
47
48
49
50
51
52
@dataclass
class SessionMessage:
    """A message with specific metadata for transport-specific features."""

    message: JSONRPCMessage
    metadata: MessageMetadata = None