基于 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 # 业务封装
快速开始
-
创建 uv 虚拟环境(已在
.venv目录演示,如需重新创建可按需运行):uv venv .venv source .venv/bin/activate # Windows 使用 .venv\\Scripts\\activate
-
安装依赖:
uv sync # 或 uv pip install -r pyproject.toml # Windows 如需托盘/热键支持,安装额外依赖: uv pip install .[windows]
-
运行 MCP 服务器(stdio 模式):
uv run app-launcher-mcp # 或指定参数: uv run app-launcher-mcp --no-auto-discover # 禁用自动发现 uv run app-launcher-mcp --transport stdio # 指定 Transport
-
在 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|...简写。 - 配置文件:程序在以下路径按顺序查找(找到即停止):
~/.mcp-apps.json<工作目录>/mcp-apps.json~/.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控制。
- Windows:内置 QQ、微信、VS Code 等常见路径,并扫描开始菜单
可参考 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.startfile或subprocess.Popen启动新实例。
故障排查
未找到匹配的应用:检查MCP_APPS/ 配置文件是否已加载,或在调用open_app_tool前执行reload_apps_tool。pywin32 未安装:在 Windows 环境执行uv pip install .[windows]。权限相关错误:Mac/Linux 打开.app时需确认拥有执行权限,可通过chmod +x处理。
欢迎根据需要扩展更多工具,例如批量更新应用、动态注册等。
发布到 PyPI
-
更新
pyproject.toml中的版本号,并确保代码/文档同步。 -
安装构建工具并生成分发包:
uv pip install --upgrade build twine uv build twine check dist/*
-
使用 PyPI API Token 上传:
twine upload dist/*
发布成功后,用户即可通过 pip install fastmcp-app-launcher 获取最新版本。
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file fastmcp_app_launcher-0.3.1.tar.gz.
File metadata
- Download URL: fastmcp_app_launcher-0.3.1.tar.gz
- Upload date:
- Size: 20.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
174277bb958d0d5a97551b4e8c749ee29c8f8a83096d7705d6ddd97efa1c9ffa
|
|
| MD5 |
72c7883a527473cd249c55a2da77b9f7
|
|
| BLAKE2b-256 |
9dd1d94c10371a97312b1e2ce788fa8ed781369d74058190171530d8710c8018
|
File details
Details for the file fastmcp_app_launcher-0.3.1-py3-none-any.whl.
File metadata
- Download URL: fastmcp_app_launcher-0.3.1-py3-none-any.whl
- Upload date:
- Size: 19.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f6dd566d3f2c66a1e06ea07587c8c25d7e78f08f7cb1f9988d516a3f20e91141
|
|
| MD5 |
75831a4d6f525c03de40481e0f4983ab
|
|
| BLAKE2b-256 |
a037981881534b90c26dcba9dc27998aec94cf7bae76160dbdd0fad802e5966b
|