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 处理。

QQ/微信托盘应用问题

问题:QQ或微信在系统托盘时,激活失败导致打开新登录窗口。

原因:Windows托盘应用的状态检测复杂,传统窗口查找算法容易误判。

解决方案

  1. 在配置中设置 "relaunch_when_tray_hidden": true(如示例配置所示)
  2. 确保已安装 pywin32:执行 uv pip install .[windows]
  3. 使用最新版本的激活逻辑,已针对QQ/微信等托盘应用优化

技术细节:新版本改进了托盘状态检测算法,能正确识别"有正常窗口样式但不可见"的托盘应用,避免误判为普通隐藏窗口。

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

发布到 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.2.3.tar.gz (31.1 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.2.3-py3-none-any.whl (34.4 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for fastmcp_app_launcher_test-0.2.3.tar.gz
Algorithm Hash digest
SHA256 54bf5443db03835641f729969e03e0c0be3d559da7139ab651814696d8c8a1a4
MD5 0f91dd20a7f062c9b6ef2443abd4030c
BLAKE2b-256 22aed69fbb10c3869cb4f6342990198e375f9d9e37df6e70019557e1c0ebfcf2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fastmcp_app_launcher_test-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 96e48affc0eeb480dba7853fea5d30f80ce7e680c80a222497cc69f2c25b9c84
MD5 2cbaadead219ee3e2c30e1a16ee57277
BLAKE2b-256 636dfc9fd3f6656dc637a86c4b2b87a366a7e265cd4523c55c5700af8f705f62

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