Skip to main content

Python SDK for piping local MCP stdio servers to Xiaozhi WebSocket endpoints.

Project description

MCP Sample Project | MCP 示例项目

A powerful interface for extending AI capabilities through remote control, calculations, email operations, knowledge search, and more.

一个强大的接口,用于通过远程控制、计算、邮件操作、知识搜索等方式扩展AI能力。

Overview | 概述

MCP (Model Context Protocol) is a protocol that allows servers to expose tools that can be invoked by language models. Tools enable models to interact with external systems, such as querying databases, calling APIs, or performing computations. Each tool is uniquely identified by a name and includes metadata describing its schema.

MCP(模型上下文协议)是一个允许服务器向语言模型暴露可调用工具的协议。这些工具使模型能够与外部系统交互,例如查询数据库、调用API或执行计算。每个工具都由一个唯一的名称标识,并包含描述其模式的元数据。

Features | 特性

  • 🔌 Bidirectional communication between AI and external tools | AI与外部工具之间的双向通信
  • 🔄 Automatic reconnection with exponential backoff | 具有指数退避的自动重连机制
  • 📊 Real-time data streaming | 实时数据流传输
  • 🛠️ Easy-to-use tool creation interface | 简单易用的工具创建接口
  • 🔒 Secure WebSocket communication | 安全的WebSocket通信
  • ⚙️ Multiple transport types support (stdio/sse/http) | 支持多种传输类型(stdio/sse/http)

Quick Start | 快速开始

  1. Install SDK | 安装 SDK:
pip install -e .

Or install from GitHub | 或从 GitHub 安装:

pip install git+https://github.com/dairoot/mcp-calculator
  1. Set up environment variables | 设置环境变量:
export MCP_ENDPOINT=<your_mcp_endpoint>
  1. Run the calculator example | 运行计算器示例:
python -m xiaozhi_mcp calculator.py

Or run all configured servers | 或运行所有配置的服务:

python -m xiaozhi_mcp

Requires mcp_config.json configuration file with server definitions (supports stdio/sse/http transport types)

需要 mcp_config.json 配置文件定义服务器(支持 stdio/sse/http 传输类型)

Project Structure | 项目结构

  • mcp_pipe.py: Main communication pipe that handles WebSocket connections and process management | 处理WebSocket连接和进程管理的主通信管道
  • xiaozhi_mcp/: Installable Python SDK package | 可安装的 Python SDK 包
  • calculator.py: Example MCP tool implementation for mathematical calculations | 用于数学计算的MCP工具示例实现
  • requirements.txt: Project dependencies | 项目依赖

SDK Usage | SDK 使用

Install from this project directory | 在项目目录中安装:

pip install .

Install from GitHub | 从 GitHub 安装:

pip install git+https://github.com/dairoot/mcp-calculator

Run a local MCP script after installation | 安装后运行本地 MCP 脚本:

python -m xiaozhi_mcp <script.py>

The package also exposes a console command | 同时也提供命令行入口:

xiaozhi-mcp <script.py>

For legacy usage, python mcp_pipe.py <script.py> remains available.

Config-driven Servers | 通过配置驱动的服务

编辑 mcp_config.json 文件来配置服务器列表(也可设置 MCP_CONFIG 环境变量指向其他配置文件)。

配置说明:

  • 无参数时启动所有配置的服务(自动跳过 disabled: true 的条目)
  • 有参数时运行单个本地脚本文件
  • type=stdio 直接启动;type=sse/http 通过 python -m mcp_proxy 代理

Creating Your Own MCP Tools | 创建自己的MCP工具

Here's a simple example of creating an MCP tool | 以下是一个创建MCP工具的简单示例:

from mcp.server.fastmcp import FastMCP

mcp = FastMCP("YourToolName")

@mcp.tool()
def your_tool(parameter: str) -> dict:
    """Tool description here"""
    # Your implementation
    return {"success": True, "result": result}

if __name__ == "__main__":
    mcp.run(transport="stdio")

Use Cases | 使用场景

  • Mathematical calculations | 数学计算
  • Email operations | 邮件操作
  • Knowledge base search | 知识库搜索
  • Remote device control | 远程设备控制
  • Data processing | 数据处理
  • Custom tool integration | 自定义工具集成

Requirements | 环境要求

  • Python 3.7+
  • websockets>=11.0.3
  • python-dotenv>=1.0.0
  • mcp>=1.8.1
  • pydantic>=2.11.4
  • mcp-proxy>=0.8.2

Contributing | 贡献指南

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

欢迎贡献代码!请随时提交Pull Request。

License | 许可证

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

本项目采用MIT许可证 - 详情请查看LICENSE文件。

Acknowledgments | 致谢

  • Thanks to all contributors who have helped shape this project | 感谢所有帮助塑造这个项目的贡献者
  • Inspired by the need for extensible AI capabilities | 灵感来源于对可扩展AI能力的需求

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

xiaozhi_mcp-0.0.1.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

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

xiaozhi_mcp-0.0.1-py3-none-any.whl (7.6 kB view details)

Uploaded Python 3

File details

Details for the file xiaozhi_mcp-0.0.1.tar.gz.

File metadata

  • Download URL: xiaozhi_mcp-0.0.1.tar.gz
  • Upload date:
  • Size: 7.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.7

File hashes

Hashes for xiaozhi_mcp-0.0.1.tar.gz
Algorithm Hash digest
SHA256 8d10dcf04a1357f30e6415b0480c5cae28fac019cd16dc9758e02865a234c9a1
MD5 681a4cebf74a7a998034596e9127b6ac
BLAKE2b-256 e4d5f19a9bfbeb30405a9a621569fab41791bf401e165e55bc28969628c02008

See more details on using hashes here.

File details

Details for the file xiaozhi_mcp-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: xiaozhi_mcp-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 7.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.7

File hashes

Hashes for xiaozhi_mcp-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d34ca3b7e3ad861d759dfe9b92765c6216377b58ccd9685066528e838e9b3800
MD5 34934907442df02e75d4888e5ad7f811
BLAKE2b-256 7887eea4f9d4f0b2c5c82bafe385309cf63ced0e6f1fb96a70e2e84415e8ffa2

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