Интеграция Strava API с Model Context Protocol (MCP) SDK

Интеграция Strava API с Model Context Protocol (MCP) SDK

镜子 (jìng zi)

MCP-Mirror

研究与数据
访问服务器

README

将 Strava API 与 Model Context Protocol (MCP) SDK 集成

CI Codecov Python License: MIT Ruff

用于分析训练并基于 Strava 数据使用 Model Context Protocol SDK 获取建议的集成。

🚀 功能

  • 分析来自 Strava 的训练
  • 训练建议
  • 自动更新令牌
  • API 请求的速率限制

📋 要求

⚙️ 安装

# 克隆存储库
git clone https://github.com/rbctmz/mcp-server-strava.git
cd mcp-server-strava

# 通过 uv 安装(推荐)
curl -LsSf https://astral.sh/uv/install.sh | sh
uv pip install .

# 以开发模式安装
uv pip install -e ".[dev]"

安装 MCP SDK

uv add "mcp[cli]"

🔧 配置

配置 Strava API

  1. 转到 API 设置页面
  2. 创建应用程序:
    • Application Name: MCP Strava Integration
    • Category: Training Analysis
    • Website: http://localhost
    • Authorization Callback Domain: localhost

配置环境

  1. 创建一个包含环境变量的文件:

    cp .env-template .env
    
  2. 获取访问令牌:

    python scripts/auth.py
    
  3. 检查配置:

    mcp dev src/server.py
    curl -X GET "http://localhost:8000/activities"
    

📚 API 和示例

资源和工具

类型 名称 描述
资源 strava://activities 活动列表
资源 strava://activities/{id} 活动详情
资源 strava://athlete/zones 训练区域
资源 strava://athlete/clubs 运动员俱乐部
资源 strava://gear/{gear_id} 装备信息
工具 analyze_activity(activity_id) 分析训练
工具 analyze_training_load(activities) 分析负荷
工具 get_activity_recommendations() 建议

使用示例

from mcp import ClientSession

# 获取活动
async with ClientSession() as session:
    activities = await session.read_resource("strava://activities")
    activity = await session.read_resource("strava://activities/12345678")

# 分析训练
result = analyze_activity(activity_id="12345678")
"""
{
    "type": "Run",
    "distance": 5000,
    "moving_time": 1800,
    "analysis": {
        "pace": 5.5,  # 分钟/公里
        "effort": "中等"
    }
}
"""

# 分析负荷
summary = analyze_training_load(activities)
"""
{
    "activities_count": 10,
    "total_distance": 50.5,  # 公里
    "total_time": 5.2,      # 小时
    "heart_rate_zones": {
        "easy": 4,    # 心率 < 120
        "medium": 4,  # 心率 120-150
        "hard": 2     # 心率 > 150
    }
}
"""

# 获取训练区域
async with ClientSession() as session:
    zones = await session.read_resource("strava://athlete/zones")
    """
    {
        "heart_rate": {
            "custom_zones": true,
            "zones": [
                {"min": 0, "max": 120, "name": "Z1 - Recovery"},
                {"min": 120, "max": 150, "name": "Z2 - Endurance"},
                {"min": 150, "max": 170, "name": "Z3 - Tempo"},
                {"min": 170, "max": 185, "name": "Z4 - Threshold"},
                {"min": 185, "max": -1, "name": "Z5 - Anaerobic"}
            ]
        },
        "power": {
            "zones": [
                {"min": 0, "max": 180},
                {"min": 181, "max": 250},
                {"min": 251, "max": 300},
                {"min": 301, "max": 350},
                {"min": 351, "max": -1}
            ]
        }
    }
    """

🛠 开发

CI/CD 和安全

  • Coverage
  • Tests
  • Ruff

GitHub Actions 中的检查

类型 工具 描述
代码检查 ruff 格式化和分析代码
测试 pytest 单元测试和集成测试
覆盖率 pytest-cov 代码覆盖率报告

安全和密钥

  1. 保护令牌:

    • .env.gitignore
    • CI/CD 的 GitHub Secrets
    • 速率限制:100 个请求/15 分钟
  2. 配置密钥:

    # 在 GitHub 中:Settings → Secrets → Actions
    STRAVA_CLIENT_ID=<client_id>
    STRAVA_CLIENT_SECRET=<client_secret>
    STRAVA_REFRESH_TOKEN=<refresh_token>
    

贡献

  1. Fork 存储库

  2. 安装依赖项:uv pip install -e ".[dev]"

  3. 创建分支:git checkout -b feature/name

  4. 检查更改:

    ruff format .
    ruff check .
    pytest --cov=src
    
  5. 创建 Pull Request

📫 支持

📄 许可证

MIT

推荐服务器

Crypto Price & Market Analysis MCP Server

Crypto Price & Market Analysis MCP Server

一个模型上下文协议 (MCP) 服务器,它使用 CoinCap API 提供全面的加密货币分析。该服务器通过一个易于使用的界面提供实时价格数据、市场分析和历史趋势。 (Alternative, slightly more formal and technical translation): 一个模型上下文协议 (MCP) 服务器,利用 CoinCap API 提供全面的加密货币分析服务。该服务器通过用户友好的界面,提供实时价格数据、市场分析以及历史趋势数据。

精选
TypeScript
MCP PubMed Search

MCP PubMed Search

用于搜索 PubMed 的服务器(PubMed 是一个免费的在线数据库,用户可以在其中搜索生物医学和生命科学文献)。 我是在 MCP 发布当天创建的,但当时正在度假。 我看到有人在您的数据库中发布了类似的服务器,但还是决定发布我的服务器。

精选
Python
mixpanel

mixpanel

连接到您的 Mixpanel 数据。 从 Mixpanel 分析查询事件、留存和漏斗数据。

精选
TypeScript
Sequential Thinking MCP Server

Sequential Thinking MCP Server

这个服务器通过将复杂问题分解为顺序步骤来促进结构化的问题解决,支持修订,并通过完整的 MCP 集成来实现多条解决方案路径。

精选
Python
Nefino MCP Server

Nefino MCP Server

为大型语言模型提供访问德国可再生能源项目新闻和信息的能力,允许按地点、主题(太阳能、风能、氢能)和日期范围进行筛选。

官方
Python
Vectorize

Vectorize

将 MCP 服务器向量化以实现高级检索、私有深度研究、Anything-to-Markdown 文件提取和文本分块。

官方
JavaScript
Mathematica Documentation MCP server

Mathematica Documentation MCP server

一个服务器,通过 FastMCP 提供对 Mathematica 文档的访问,使用户能够从 Wolfram Mathematica 检索函数文档和列出软件包符号。

本地
Python
kb-mcp-server

kb-mcp-server

一个 MCP 服务器,旨在实现便携性、本地化、简易性和便利性,以支持对 txtai “all in one” 嵌入数据库进行基于语义/图的检索。任何 tar.gz 格式的 txtai 嵌入数据库都可以被加载。

本地
Python
Research MCP Server

Research MCP Server

这个服务器用作 MCP 服务器,与 Notion 交互以检索和创建调查数据,并与 Claude Desktop Client 集成以进行和审查调查。

本地
Python
Cryo MCP Server

Cryo MCP Server

一个API服务器,实现了模型补全协议(MCP),用于Cryo区块链数据提取,允许用户通过任何兼容MCP的客户端查询以太坊区块链数据。

本地
Python