|
cxxmcp 1.1.6
C++ MCP SDK
|
Native transport-contract server for Streamable HTTP. More...
#include <http_transport.hpp>
Public Member Functions | |
| StreamableHttpServerTransport (StreamableHttpServerTransportOptions options) | |
| StreamableHttpServerTransport (const StreamableHttpServerTransport &)=delete | |
| StreamableHttpServerTransport & | operator= (const StreamableHttpServerTransport &)=delete |
| std::string_view | name () const noexcept override |
| Human-readable transport name for diagnostics. | |
| protocol::Json | diagnostics () const override |
| Structured implementation diagnostics. | |
| core::Result< core::Unit > | send (TxMessage message) override |
| Sends one JSON-RPC message to the peer. | |
| core::Result< std::optional< RxMessage > > | receive () override |
| Receives the next JSON-RPC message from the peer. | |
| std::optional< StreamableHttpServerMessageContext > | last_received_context () const |
| core::Result< core::Unit > | close () override |
| Closes the transport and unblocks receive() where possible. | |
| void | wait_until_ready () override |
| Blocks until the transport is ready to process messages. | |
Additional Inherited Members | |
Public Types inherited from mcp::transport::Transport< Role > | |
| using | TxMessage = typename MessageTraits< Role >::TxMessage |
| using | RxMessage = typename MessageTraits< Role >::RxMessage |
Native transport-contract server for Streamable HTTP.
receive() owns a background legacy HTTP server loop and returns inbound client requests and notifications. Sending a response completes a client request previously returned by receive(); sending a request or notification delivers it to the active HTTP session through the established server HTTP transport. Concurrent receive() calls are not supported.
|
overridevirtual |
Closes the transport and unblocks receive() where possible.
Implements mcp::transport::Transport< Role >.
|
overridevirtual |
Structured implementation diagnostics.
The default keeps the core contract narrow. Transports with useful state may return keys such as "name", "closed", "inflight", or backend-specific counters. Diagnostics are not part of the wire protocol.
Reimplemented from mcp::transport::Transport< Role >.
|
overridevirtualnoexcept |
Human-readable transport name for diagnostics.
Implements mcp::transport::Transport< Role >.
|
overridevirtual |
Receives the next JSON-RPC message from the peer.
receive() is the sequential inbound side. A successful std::nullopt return is an orderly end-of-stream signal, not a parse or transport error.
Implements mcp::transport::Transport< Role >.
|
overridevirtual |
Sends one JSON-RPC message to the peer.
Concurrency safety is implementation-specific and must be documented by the concrete transport.
Implements mcp::transport::Transport< Role >.
|
overridevirtual |
Blocks until the transport is ready to process messages.
The default is a no-op. Transports that need asynchronous startup (e.g. binding a socket) override this to block until the underlying resource is available.
Reimplemented from mcp::transport::Transport< Role >.