Skip to main content

基于 fastmcp 的跨平台应用启动 MCP 服务

Project description

FastMCP 应用启动器

使用 fastmcp 构建的跨平台 Model Context Protocol 服务,可通过 MCP 客户端(如 Claude Desktop)列出并打开本地应用,针对 Windows 托盘应用提供热键与窗口激活增强。

安装

pip install fastmcp-app-launcher
# 或使用 uv
uv pip install fastmcp-app-launcher

安装完成后终端会提供 app-launcher-mcp 命令,可直接在 MCP 客户端中调用。

目录结构

fastmcp_app_launcher/
├── mcp-apps.example.json    # 示例配置
├── pyproject.toml           # uv/fastmcp 配置
├── README.md
└── src/app_launcher_mcp
    ├── __init__.py
    ├── activator.py         # Windows 激活逻辑
    ├── apps.py              # 配置加载与搜索
    ├── server.py            # FastMCP 入口
    └── service.py           # 业务封装

快速开始

  1. 创建 uv 虚拟环境(已在 .venv 目录演示,如需重新创建可按需运行):

    uv venv .venv
    source .venv/bin/activate  # Windows 使用 .venv\\Scripts\\activate
    
  2. 安装依赖:

    uv sync          # 或 uv pip install -r pyproject.toml
    # Windows 如需托盘/热键支持,安装额外依赖:
    uv pip install .[windows]
    
  3. 运行 MCP 服务器(stdio 模式):

    uv run app-launcher-mcp
    # 或指定参数:
    uv run app-launcher-mcp --no-auto-discover   # 禁用自动发现
    uv run app-launcher-mcp --transport stdio    # 指定 Transport
    
  4. 在 MCP 客户端中配置:

    {
      "command": "uv",
      "args": ["run", "--directory", "/Users/fjc/Desktop/项目/skills/python/fastmcp_app_launcher", "app-launcher-mcp"],
      "env": {
        "MCP_APPS": "QQ;C:/Program Files/Tencent/QQ/Bin/QQ.exe;qq,tencent;Ctrl+Alt+Z"
      }
    }
    

应用配置

  • 环境变量 MCP_APPS:支持 JSON 数组或 name;path;keywords;hotkey|... 简写。
  • 配置文件:程序在以下路径按顺序查找(找到即停止):
    1. ~/.mcp-apps.json
    2. <工作目录>/mcp-apps.json
    3. ~/.config/mcp-apps/config.json
  • 自动发现
    • Windows:内置 QQ、微信、VS Code 等常见路径,并扫描开始菜单 .lnk 快捷方式(目录可通过环境变量 MCP_WINDOWS_SHORTCUT_DIRS 指定,使用 os.pathsep 分隔)。
    • macOS:默认遍历 /Applications/System/Applications~/Applications 等目录,可使用 MCP_MAC_APP_DIRS 覆盖;扫描数量由 MCP_AUTO_DISCOVER_LIMIT 控制。

可参考 mcp-apps.example.json 快速自定义列表。

支持的应用字段(JSON 配置文件)

  • name:应用名
  • path:可执行文件或 .lnk 路径
  • keywords:匹配关键词数组
  • hotkey:可选,全局或应用支持的唤起热键(如 Ctrl+Alt+Z
  • relaunch_when_tray_hidden:可选,Windows 托盘隐藏时尝试通过 Shell 再次“打开”以唤起主窗体(默认 false)
  • shell_fallback_on_fail:可选,所有激活方法失败后再通过 Shell 打开一次作为兜底(默认 false)

可用工具

工具名 描述
list_apps_tool 返回当前注册的全部应用及数量
open_app_tool 参数 app_name、可选 reload_before,用于打开或激活应用
reload_apps_tool 重新加载配置/环境,并返回最新应用数

工具返回 structuredContent 中包含的字段示例:

{
  "query": "wechat",
  "app": {"name": "微信", "path": "...", "hotkey": "Ctrl+Alt+W"},
  "execution": {"success": true, "message": "通过热键激活窗口成功"}
}

Windows 特性

  • 托盘激活:若安装 pywin32,服务会尝试发送热键、定位现有窗口并置前。
  • pywinauto 支持:可选安装以在托盘图标无法响应热键时通过 UI 自动化置顶窗口。
  • 自动回退:当相关库缺失时,会直接调用 os.startfilesubprocess.Popen 启动新实例。

故障排查

  • 未找到匹配的应用:检查 MCP_APPS / 配置文件是否已加载,或在调用 open_app_tool 前执行 reload_apps_tool
  • pywin32 未安装:在 Windows 环境执行 uv pip install .[windows]
  • 权限相关错误:Mac/Linux 打开 .app 时需确认拥有执行权限,可通过 chmod +x 处理。

欢迎根据需要扩展更多工具,例如批量更新应用、动态注册等。

发布到 PyPI

  1. 更新 pyproject.toml 中的版本号,并确保代码/文档同步。

  2. 安装构建工具并生成分发包:

    uv pip install --upgrade build twine
    uv build
    twine check dist/*
    
  3. 使用 PyPI API Token 上传:

    twine upload dist/*
    

发布成功后,用户即可通过 pip install fastmcp-app-launcher 获取最新版本。

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

fastmcp_app_launcher_test-0.1.1.tar.gz (21.7 kB view details)

Uploaded Source

Built Distribution

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

fastmcp_app_launcher_test-0.1.1-py3-none-any.whl (20.7 kB view details)

Uploaded Python 3

File details

Details for the file fastmcp_app_launcher_test-0.1.1.tar.gz.

File metadata

File hashes

Hashes for fastmcp_app_launcher_test-0.1.1.tar.gz
Algorithm Hash digest
SHA256 f183ea98f039d1e7a5a7ec49225d05a2459010a4d674f310ab48e96fa082d2e3
MD5 e47becfde8dd9b04b8f25a1adf8e965d
BLAKE2b-256 31ba6280172d2d5ba1efa30ed9d48beab8f3a499419b282c72a8765f1b4947a4

See more details on using hashes here.

File details

Details for the file fastmcp_app_launcher_test-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for fastmcp_app_launcher_test-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ff92a9eb38c58ad65b6a6eb92c9b231c87e3ce26f43dffa826c1c2fa3480b591
MD5 b980b74ad8cb8f30f581fa4d2d891c8a
BLAKE2b-256 5041a6ea7c266840c76d9aae994521958a341118a0e5dbfbf3fb181397a0393f

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