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.5.tar.gz (16.3 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.5-py3-none-any.whl (15.7 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for fastmcp_app_launcher-0.2.5.tar.gz
Algorithm Hash digest
SHA256 79055d58e86e5a36804a9b029af2d1d23fc3ffd48444fec6e98d279b24604c02
MD5 e2cd3e3e0aeaf50de9a2f3585e0d33f8
BLAKE2b-256 df82456075dbbebca275e868a5a8385d6406978157bbc752fb4fae91c132b719

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fastmcp_app_launcher-0.2.5-py3-none-any.whl
Algorithm Hash digest
SHA256 5659cbe8c3a7d58e42cec024ed830e9ada62aba037f1e38d430cd3af6d9bbf78
MD5 698605de4e7475f37cf5bb3b40fc5c4e
BLAKE2b-256 901bac886c7c586e5190bf6008b5fa8a863f17b1f1ad2e973512f4ea1416639a

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