Skip to main content

MCP Server template for better AI Coding with weather service tools

Project description

MCP Server template for better AI Coding

Inspired by MCP Official Tutorial

Overview

This template provides a streamlined foundation for building Model Context Protocol (MCP) servers in Python. It's designed to make AI-assisted development of MCP tools easier and more efficient.

Features

  • Ready-to-use MCP server implementation
  • Configurable transport modes (stdio, SSE)
  • Example weather service integration (NWS API)
  • Clean, well-documented code structure
  • Minimal dependencies
  • Embedded MCP specifications and documentation for improved AI tool understanding

Cursor Rules Integration

This project uses Cursor Rules for improved AI coding assistance, with patterns from Awesome Cursor Rules.

  • Clean Code Guidelines: Built-in clean code rules help maintain consistency and quality
  • Enhanced AI Understanding: Rules provide context that helps AI assistants generate better code
  • Standardized Patterns: Follow established best practices for MCP server implementation

Cursor Rules help both AI coding assistants and human developers maintain high code quality standards and follow best practices.

Integrated MCP Documentation

This template includes comprehensive MCP documentation directly in the project:

  • Complete MCP Specification (protocals/mcp.md): The full Model Context Protocol specification that defines how AI models can interact with external tools and resources. This helps AI assistants understand MCP concepts and implementation details without requiring external references.

  • Python SDK Guide (protocals/sdk.md): Detailed documentation for the MCP Python SDK, making it easier for AI tools to provide accurate code suggestions and understand the library's capabilities.

  • Example Implementation (protocals/example_weather.py): A practical weather service implementation demonstrating real-world MCP server patterns and best practices.

Having these resources embedded in the project enables AI coding assistants to better understand MCP concepts and provide more accurate, contextually relevant suggestions during development.

Requirements

  • Python 3.12+
  • Dependencies:
    • mcp>=1.4.1
    • httpx>=0.28.1
    • starlette>=0.46.1
    • uvicorn>=0.34.0

Getting Started

Installation

  1. Clone this repository:

    git clone https://github.com/yourusername/mcp-server-python-template.git
    cd mcp-server-python-template
    
  2. Create a virtual environment and install dependencies:

    python -m venv .venv
    source .venv/bin/activate  # On Windows: .venv\Scripts\activate
    pip install -e .
    

Running the Example Server

The template includes a weather service example that demonstrates how to build MCP tools:

# Run with stdio transport (for CLI tools)
python server.py --transport stdio

# Run with SSE transport (for web applications)
python server.py --transport sse --host 0.0.0.0 --port 8080

Creating Your Own MCP Tools

To create your own MCP tools:

  1. Import the necessary components from mcp:

    from mcp.server.fastmcp import FastMCP
    
  2. Initialize your MCP server with a namespace:

    mcp = FastMCP("your-namespace")
    
  3. Define your tools using the @mcp.tool() decorator:

    @mcp.tool()
    async def your_tool_function(param1: str, param2: int) -> str:
        """
        Your tool description.
        
        Args:
            param1: Description of param1
            param2: Description of param2
            
        Returns:
            The result of your tool
        """
        # Your implementation here
        return result
    
  4. Run your server using the appropriate transport:

    mcp.run(transport='stdio')  # or set up SSE as shown in server.py
    

Project Structure

  • server.py: Main MCP server implementation with example weather tools
  • main.py: Simple entry point for custom code
  • protocals/: Documentation and example protocols
    • mcp.md: Complete MCP specification (~7000 lines)
    • sdk.md: MCP Python SDK documentation
    • example_weather.py: Example weather service implementation
  • pyproject.toml: Project dependencies and metadata

Understanding MCP

The Model Context Protocol (MCP) is a standardized way for AI models to interact with external tools and resources. Key concepts include:

  • Tools: Functions that models can call to perform actions or retrieve information
  • Resources: External data sources that models can reference
  • Transports: Communication channels between clients and MCP servers (stdio, SSE)
  • Namespaces: Logical groupings of related tools

This template is specifically designed to make working with MCP more accessible, with the integrated documentation helping AI tools better understand and generate appropriate code for MCP implementations.

Learning Resources

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

iflow_mcp_mcp_server_python_template-0.1.0.tar.gz (6.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file iflow_mcp_mcp_server_python_template-0.1.0.tar.gz.

File metadata

  • Download URL: iflow_mcp_mcp_server_python_template-0.1.0.tar.gz
  • Upload date:
  • Size: 6.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.10 {"installer":{"name":"uv","version":"0.9.10"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_mcp_server_python_template-0.1.0.tar.gz
Algorithm Hash digest
SHA256 ed2e307d8418a17d39cfd67a95c81c4f61d113c114ddfc2e7277c29bc5f10462
MD5 2f5cf29813b6f19db2100df213601b13
BLAKE2b-256 8aa5f195f29066e8cf39cba906fb5be02263177122f84af44a2e2d9c0b48dd49

See more details on using hashes here.

File details

Details for the file iflow_mcp_mcp_server_python_template-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: iflow_mcp_mcp_server_python_template-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 7.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.10 {"installer":{"name":"uv","version":"0.9.10"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_mcp_server_python_template-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a39e182a1eda6313a62062293fc26fa353102315d13267025f93832564ae979b
MD5 eafe812f7ba282b86167c37d2a697729
BLAKE2b-256 3a717403f55874922485304fdc302f45a34451e3dc53bdbb7afcf7487d727e15

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page