Build production-ready Model Context Protocol servers with confidence
This framework provides everything you need to build production-ready MCP servers in Rust. It's been developed and proven through a real-world home automation server with 30+ tools that successfully integrates with MCP Inspector, Claude Desktop, and HTTP clients.
The Model Context Protocol enables AI assistants to securely connect to and interact with external systems through tools, resources, and prompts. Instead of AI models having static knowledge, they can dynamically access live data and perform actions through MCP servers.
ποΈ Production-Proven: This framework powers a working Loxone home automation server that handles real-world complexity - device control, sensor monitoring, authentication, and concurrent operations.
π§ Complete Infrastructure: You focus on your domain logic (databases, APIs, file systems) while the framework handles protocol compliance, transport layers, security, and monitoring.
π‘ Multiple Transport Support: Works with Claude Desktop (stdio), web applications (HTTP), real-time apps (WebSocket), and tools like MCP Inspector.
Add to your Cargo.toml:
[dependencies]
pulseengine-mcp-server = "0.4.1"
pulseengine-mcp-protocol = "0.4.1"
tokio = { version = "1.0", features = ["full"] }
async-trait = "0.1"Create your first MCP server:
use pulseengine_mcp_server::{McpServer, McpBackend, ServerConfig};
use pulseengine_mcp_protocol::*;
use async_trait::async_trait;
#[derive(Clone)]
struct MyBackend;
#[async_trait]
impl McpBackend for MyBackend {
    type Error = Box<dyn std::error::Error + Send + Sync>;
    type Config = ();
    async fn initialize(_: Self::Config) -> Result<Self, Self::Error> {
        Ok(MyBackend)
    }
    fn get_server_info(&self) -> ServerInfo {
        ServerInfo {
            protocol_version: ProtocolVersion::default(),
            capabilities: ServerCapabilities {
                tools: Some(ToolsCapability { list_changed: Some(false) }),
                ..Default::default()
            },
            server_info: Implementation {
                name: "My MCP Server".to_string(),
                version: "1.0.0".to_string(),
            },
            instructions: Some("A simple example server".to_string()),
        }
    }
    async fn list_tools(&self, _: PaginatedRequestParam) -> Result<ListToolsResult, Self::Error> {
        Ok(ListToolsResult {
            tools: vec![
                Tool {
                    name: "hello".to_string(),
                    description: "Say hello to someone".to_string(),
                    input_schema: serde_json::json!({
                        "type": "object",
                        "properties": {
                            "name": {"type": "string", "description": "Name to greet"}
                        },
                        "required": ["name"]
                    }),
                }
            ],
            next_cursor: String::new(),
        })
    }
    async fn call_tool(&self, request: CallToolRequestParam) -> Result<CallToolResult, Self::Error> {
        match request.name.as_str() {
            "hello" => {
                let name = request.arguments
                    .and_then(|args| args.get("name"))
                    .and_then(|v| v.as_str())
                    .unwrap_or("World");
                Ok(CallToolResult {
                    content: vec![Content::text(format!("Hello, {}!", name))],
                    is_error: Some(false),
                })
            }
            _ => Err("Unknown tool".into()),
        }
    }
    // Simple implementations for unused features
    async fn list_resources(&self, _: PaginatedRequestParam) -> Result<ListResourcesResult, Self::Error> {
        Ok(ListResourcesResult { resources: vec![], next_cursor: String::new() })
    }
    async fn read_resource(&self, _: ReadResourceRequestParam) -> Result<ReadResourceResult, Self::Error> {
        Err("No resources".into())
    }
    async fn list_prompts(&self, _: PaginatedRequestParam) -> Result<ListPromptsResult, Self::Error> {
        Ok(ListPromptsResult { prompts: vec![], next_cursor: String::new() })
    }
    async fn get_prompt(&self, _: GetPromptRequestParam) -> Result<GetPromptResult, Self::Error> {
        Err("No prompts".into())
    }
}
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let backend = MyBackend::initialize(()).await?;
    let config = ServerConfig::default();
    let mut server = McpServer::new(backend, config).await?;
    server.run().await?;
    Ok(())
}π§ mcp-protocol - Core Protocol Types
- MCP request/response types with validation
- JSON-RPC 2.0 support and error handling
- Schema validation for tool parameters
ποΈ mcp-server - Server Infrastructure
- Pluggable backend system via McpBackendtrait
- Request routing and protocol compliance
- Middleware integration for auth, security, monitoring
π‘ mcp-transport - Multiple Transports
- stdio (Claude Desktop), HTTP (web apps), WebSocket (real-time)
- MCP Inspector compatibility with content negotiation
- Session management and CORS support
π mcp-auth - Authentication Framework
- API key management with role-based access control
- Rate limiting and IP whitelisting
- Audit logging and security features
π‘οΈ mcp-security - Security Middleware
- Input validation and XSS/injection prevention
- Request size limits and parameter validation
- CORS policies and security headers
π mcp-monitoring - Observability
- Health checks and metrics collection
- Performance tracking and request tracing
- Integration with monitoring systems
π mcp-logging - Structured Logging
- JSON logging with correlation IDs
- Automatic credential sanitization
- Security audit trails
π₯οΈ mcp-cli & mcp-cli-derive - CLI Integration
- Command-line interface generation
- Configuration management
- Derive macros for backends
π Hello World
Complete minimal MCP server demonstrating basic concepts.
ποΈ Backend Example
Shows advanced backend implementation patterns.
π₯οΈ CLI Example
Demonstrates CLI integration and configuration.
The framework was extracted from a production Loxone home automation server that provides:
- 30+ Tools - Complete home automation control (lighting, climate, security, energy)
- Multiple Transports - Works with Claude Desktop, MCP Inspector, n8n workflows
- Production Security - API keys, rate limiting, input validation, audit logging
- Real-Time Integration - WebSocket support for live device status updates
- Proven Reliability - Handles concurrent operations and error conditions
# Build all framework crates
cargo build --workspace
# Test all crates
cargo test --workspace
# Run examples
cargo run --bin hello-world-server- Choose Your Domain - What system do you want to make accessible via MCP?
- Implement McpBackend - Define your tools, resources, and prompts
- Configure Transport - stdio for Claude Desktop, HTTP for web clients
- Add Security - Authentication, validation, and monitoring as needed
- Deploy - Native binary, Docker container, or WebAssembly
βββββββββββββββββββ    βββββββββββββββββββ    βββββββββββββββββββ
β   MCP Clients   β    β  Your Backend   β    β External Systemsβ
β                 β    β                 β    β                 β
β β’ Claude Desktopβ    β β’ Tools         β    β β’ Databases     β
β β’ MCP Inspector βββββΊβ β’ Resources     βββββΊβ β’ APIs          β
β β’ Web Apps      β    β β’ Prompts       β    β β’ File Systems  β
β β’ Custom Clientsβ    β                 β    β β’ Hardware      β
βββββββββββββββββββ    βββββββββββββββββββ    βββββββββββββββββββ
         β                       β
         β              βββββββββββββββββββ
         β              β MCP Framework   β
         β              β                 β
         ββββββββββββββββΊβ β’ Protocol      β
                        β β’ Transport     β
                        β β’ Security      β
                        β β’ Monitoring    β
                        βββββββββββββββββββ
This framework grows from real-world usage. The most valuable contributions come from:
- New Backend Examples - Show how to integrate different types of systems
- Production Patterns - Share patterns from your own MCP server deployments
- Client Compatibility - Test with different MCP clients and report issues
- Performance Improvements - Optimizations based on real usage patterns
- Security Enhancements - Better validation, authentication, or audit capabilities
- Documentation - docs.rs/pulseengine-mcp-protocol
- Issues - GitHub Issues
- Discussions - GitHub Discussions
Licensed under either of:
- Apache License, Version 2.0 (LICENSE-APACHE)
- MIT license (LICENSE-MIT)
at your option.
Built by developers who needed a robust MCP framework for real production use. Start building your MCP server today with confidence that the foundation has been proven in demanding real-world scenarios.