The Enterprise MCP Server, or mcp-ectors for short, is an enterprise-ready, high-performance, and secure MCP server designed to enable seamless integration and interaction between large language models (LLMs) and various tools, resources, and workflow prompts. Built using Rust, Wasm, and actors, it is optimized for performance, security, and scalability, making it a great fit for enterprise environments.
To get started with mcp-ectors, make sure you have the following installed:
shell
git clone https://github.com/yourusername/mcp-ectors.git
cd mcp-ectors
Run the server:
shell
cargo run
The server will start on http://localhost:8080/sse.
Start with the Goose Desktop: In Goose Desktop (a companion tool), you can add extensions, choose SSE as the transport, and use the following URL:
httpspec
http://localhost:8080/sse
MCP-ectors enables you to create and register new routers through the Router Trait. To add a new router, implement the Router
trait for your new router, following the examples of the existing CounterRouter or HelloWorldRouter.
use exports::wasix::mcp::router::{Role::User, Annotations, ToolsCapability, ResourcesCapability, PromptsCapability, CallToolResult, Content::Text, GetPromptResult, Guest, McpResource, Prompt, PromptMessage, PromptMessageContent, PromptMessageRole, ReadResourceResult, ResourceContents, ResourceError, ServerCapabilities, TextContent, TextResourceContents, Tool, ToolError, PromptError, Value};
wit_bindgen::generate!({
path: "wit/world.wit",
world: "mcp",
});
#[derive(Clone)]
pub struct MyRouter;
impl Guest for MyRouter {
fn name() -> String {
"MyRouter".to_string()
}
fn instructions() -> String {
"Your instructions go here".to_string()
}
fn capabilities() -> ServerCapabilities {
ServerCapabilities {
tools: Some(ToolsCapability{ list_changed: Some(true) }),
resources: Some(ResourcesCapability{ subscribe: Some(true), list_changed: Some(false)}),
prompts: Some(PromptsCapability{ list_changed: Some(true) }),
}
}
fn list_tools() -> Vec<Tool> {
...
}
fn call_tool(
tool_name: String,
arguments: Value,
) -> Result<CallToolResult, ToolError> {
...
}
fn list_resources() -> Vec<McpResource> {
...
}
fn read_resource(
uri: String,
) -> Result<ReadResourceResult, ResourceError> {
...
}
fn list_prompts() -> Vec<Prompt> {
...
}
fn get_prompt(prompt_name: String) -> Result<GetPromptResult, PromptError> {
...
}
}
export!(YourRouter);
In MCP, tools, resources, and prompts are registered as routerid_tool
, routerid_prompt
, and routerid_resource
to keep everything well-organized. The Router Service Manager adds new routers by dropping the .wasm file in the wasm directory the server loads from.
Just start the server via mcp-ectors start --wasm_path wasm and drop your MPC router wasms in the directory.
Server Builder:
server_builder
determines the transport layer. Currently, SSE is supported. Future versions will include stdio and wasi transport.Router Service Manager:
RouterServiceManager
is responsible for registering multiple routers and ensuring that each router can handle requests without the need for new connections.Log Configuration:
LogConfig
struct.Transport Actor:
JsonRPCMessages
to be sent to the client.Router:
Standard Actors:
let log_config = LogConfig {
log_dir: "logs".to_string(),
log_file: "server.log".to_string(),
level: Level::INFO,
};
The MCP SSE Server (mcp-ectors) is built for high performance, scalability, and ease of use. With actors, Rust, and a clean architecture for managing multiple routers, it makes working with LLMs, tools, and resources effortless.
Feel free to contribute, test, and expand the system for your enterprise use cases. You can rely on mcp-ectors to power your next-generation AI applications. If your company wants to create custom routers or partner, please reach out to Maarten Ectors.
The MCP enterprise actors-based server or mcp-ectors for short.
No releases published
No packages published