米家 MCP Server

米家 MCP Server

Enables natural language control of Xiaomi smart home devices through MCP, focusing on homes, rooms, device names, and scenes without requiring protocol details.

Category
访问服务器

README

米家 MCP Server

中文文档 | English

一个基于 mijiaAPI 3.x 的产品化米家 MCP 服务。它不再要求客户端先理解 didsiid/piid/aiid 这些协议细节,而是优先面向“家庭、房间、设备名、场景名”提供更自然的查询和控制能力。

这版解决什么问题

  • 面向 AI 客户端:优先暴露稳定、清晰的产品级工具,而不是底层协议字段
  • 面向真实家庭场景:先看家庭与房间,再定位设备,再执行控制
  • 面向 MCP 标准:工具返回结构化结果,服务状态和登录状态可直接被客户端消费
  • 面向扩展:标准能力 schema、profile 驱动控制、资源模型可以继续演进

当前能力

服务与登录

  • get_service_status
  • prepare_login
  • reconnect_service
  • clear_saved_login
  • refresh_devices
  • get_tool_catalog
  • ping

家庭与设备

  • get_home_overview
  • list_homes
  • list_devices
  • get_device
  • get_device_status
  • get_device_capabilities

设备控制

  • control_by_intent
  • control_device
  • turn_on_device
  • turn_off_device
  • set_brightness
  • set_color_temperature
  • set_target_temperature
  • set_hvac_mode
  • set_fan_speed
  • set_cover_position

场景与耗材

  • list_scenes
  • execute_scene
  • get_consumable_items

MCP 资源

  • mijia://service
  • mijia://homes
  • mijia://devices
  • mijia://scenes
  • mijia://capabilities
  • mijia://tooling

安装

建议使用 Python 3.10+

poetry install

如果你不用 Poetry:

pip install -r requirements.txt

启动

poetry run python mcp_server/mcp_server.py

测试握手:

poetry run python mcp_server/mcp_test.py

登录方式

mijiaAPI 3.x 已移除账号密码登录,只支持二维码登录。

首次需要登录时,服务会:

  • 生成浏览器页:~/.miot-mcp/qr.html
  • 同时生成二维码图片:~/.miot-mcp/qr.png
  • 默认优先用系统浏览器打开 qr.html
  • 只有浏览器打不开时,才回退到图片查看器或终端二维码

认证信息会保存到:

~/.miot-mcp/auth_data.json

推荐登录主路径

  1. 调用 prepare_login
  2. 调用 get_service_status
  3. 读取 service.qr.page_pathservice.qr.image_path
  4. 完成扫码后调用 reconnect_service 或直接 refresh_devices

登录相关状态

get_service_statusmijia://service 都会返回结构化登录状态,重点字段包括:

  • service.connected
  • service.has_saved_login
  • service.qr.open_mode
  • service.qr.page_path
  • service.qr.image_path
  • service.qr.login_url
  • assistant_summary
  • next_steps.should_scan_qr

环境变量

export MIJIA_ENABLE_QR="true"
export MIJIA_QR_OPEN_MODE="browser"
export MIJIA_LOG_LEVEL="INFO"

说明:

  • MIJIA_ENABLE_QR:是否启用二维码登录,默认 true
  • MIJIA_QR_OPEN_MODE:高级配置,支持 browser / viewer / none,默认 browser
  • MIJIA_LOG_LEVEL:日志级别,支持 DEBUG / INFO / WARNING / ERROR

MCP 客户端配置示例

推荐直接使用虚拟环境里的 Python,而不是 poetry run

{
  "mcpServers": {
    "mijia": {
      "command": "/path/to/venv/bin/python",
      "args": [
        "/path/to/miot-mcp/mcp_server/mcp_server.py"
      ],
      "env": {
        "MIJIA_ENABLE_QR": "true",
        "MIJIA_QR_OPEN_MODE": "browser",
        "MIJIA_LOG_LEVEL": "INFO"
      }
    }
  }
}

推荐调用路径

对于大多数 AI 客户端,建议优先这样使用:

  1. prepare_login
  2. get_service_status
  3. refresh_devices
  4. get_home_overview
  5. get_device_status
  6. control_by_intent
  7. list_scenes
  8. execute_scene

如果客户端需要更稳定、更显式的路由,再补充:

  1. list_homes
  2. list_devices
  3. get_device
  4. get_device_capabilities
  5. control_device

常用工具说明

prepare_login

主动准备二维码登录。默认优先复用已有二维码页;如果需要重新走一轮扫码,可以传 force_reauth=true

get_service_status

返回服务连接状态、认证文件路径、日志路径、二维码页路径、下一步建议。

get_home_overview

按家庭和房间输出设备总览,适合客户端先理解家庭结构。

get_device_status

查看单个设备当前状态、可用操作和推荐下一步。

get_device_capabilities

返回标准能力 schema 和 profile 驱动控制项,适合需要稳定路由的客户端。

control_by_intent

自然语言式控制入口。适合大多数日常使用场景,例如“把卧室台灯亮度调到 30%”。

control_device

统一结构化控制入口。适合客户端已经知道目标操作和参数时使用。

使用示例

查看服务状态

{
  "name": "get_service_status",
  "arguments": {}
}

主动准备登录

{
  "name": "prepare_login",
  "arguments": {
    "reopen_qr": true
  }
}

刷新设备与房间映射

{
  "name": "refresh_devices",
  "arguments": {}
}

查看家庭总览

{
  "name": "get_home_overview",
  "arguments": {}
}

查看单个设备状态

{
  "name": "get_device_status",
  "arguments": {
    "device_name": "吸顶灯",
    "room": "客厅"
  }
}

查看能力 schema

{
  "name": "get_device_capabilities",
  "arguments": {
    "device_name": "台灯",
    "room": "卧室"
  }
}

自然语言控制

{
  "name": "control_by_intent",
  "arguments": {
    "query": "把卧室台灯亮度调到30%"
  }
}

结构化控制

{
  "name": "control_device",
  "arguments": {
    "operation": "set_color_temperature",
    "device_name": "台灯",
    "room": "卧室",
    "value": 4000
  }
}

执行场景

{
  "name": "execute_scene",
  "arguments": {
    "scene_name": "回家模式"
  }
}

当前边界

这版 MCP 重点覆盖的是最常见的家庭控制路径:

  • 家庭与房间浏览
  • 设备定位
  • 通用能力控制
  • 标准化能力 schema 暴露
  • 场景执行
  • 耗材查询

已重点覆盖的典型能力包括:

  • 开关
  • 亮度
  • 色温
  • 目标温度
  • 模式
  • 风速
  • 开合位置

更底层、更强定制的能力仍然可以继续往 control_device 扩展,但不再作为默认使用方式对外暴露。

代码结构

当前服务内部主要有三层:

  • adapter/ 负责与 mijiaAPI 交互、登录、设备发现和二维码登录体验
  • mcp_server/core/ 负责结果封装、能力计算、意图路由、标准化
  • mcp_server/device_definitions/mcp_server/device_resources/ 负责标准能力定义、意图定义和产品化资源模型

当前能力和路由不依赖插件自动发现,而是显式导入定义表。这样更清晰,也更适合 AI 客户端稳定调用。

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选