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 快速自定义列表。

可用工具

工具名 描述
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-0.2.1.tar.gz (14.8 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-0.2.1-py3-none-any.whl (14.0 kB view details)

Uploaded Python 3

File details

Details for the file fastmcp_app_launcher-0.2.1.tar.gz.

File metadata

  • Download URL: fastmcp_app_launcher-0.2.1.tar.gz
  • Upload date:
  • Size: 14.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for fastmcp_app_launcher-0.2.1.tar.gz
Algorithm Hash digest
SHA256 c9b212590a6cb7fa21b6bf855866350c9f8c52d2147c18cff908eba69f8cb53f
MD5 c3298bc6909b111ecccfe90a185d93cf
BLAKE2b-256 a3c54de5a237822125561510f15dab700897de6ec82e96089617b373913cd1c2

See more details on using hashes here.

File details

Details for the file fastmcp_app_launcher-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for fastmcp_app_launcher-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4bfb635fb9d52bcee6d2ba6b8bbca49e13247c0f69508210dac0045e68efef21
MD5 f1ed7e965a56324a4a99cac19a2b502f
BLAKE2b-256 574b75e7c04c08f682f3fbd08efc9fc28fac8c91c66618b79709742f60b09102

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