Skip to main content

A Model Context Protocol server for TrainingPeaks with analytics focus

Project description

TrainingPeaks MCP Server

PyPI Python 3.12+ License: MIT

A Model Context Protocol server for TrainingPeaks with an analytics focus — enabling real-time querying of training data, performance trends, CTL/ATL/TSB analysis, and training load optimization through Claude Desktop.

# Install and run — no cloning needed
uvx tp-mcp-server

Features

14 tools organized across 5 categories:

Category Tools Description
Auth tp_auth_status, tp_refresh_auth Check/refresh authentication
Profile tp_get_profile Athlete profile + auto-detect ID
Workouts tp_get_workouts, tp_get_workout List and detail past workouts
tp_get_planned_workouts Upcoming planned workouts with coach instructions
Fitness tp_get_fitness CTL/ATL/TSB with computed values
Peaks tp_get_peaks, tp_get_workout_prs Personal records by sport
Analytics tp_training_load_summary Weekly/monthly TSS, load ramp rate
tp_fitness_trend CTL trajectory, 7-day projection
tp_workout_analysis Efficiency factor, variability index
tp_performance_summary Sport-specific volume & consistency
tp_training_zones_distribution IF-based zone breakdown

Key feature: CTL/ATL/TSB are computed from TSS using standard exponential weighted moving averages (42-day/7-day time constants), since the TP API doesn't return these values directly.

Quick Start (recommended)

The fastest way to get running — no cloning or venv needed.

1. Install uv (if you don't have it)

uv is a fast Python package manager built by Astral (the company behind Ruff). It includes uvx, a tool that can download and run Python packages in isolated environments — no manual setup needed. It's open-source, widely adopted in the Python community, and used by projects like FastAPI, Pydantic, and many MCP servers.

curl -LsSf https://astral.sh/uv/install.sh | sh

2. Get your TrainingPeaks auth cookie

  1. Open your browser and go to trainingpeaks.com and log in
  2. Open Developer Tools (Cmd+Option+I on Mac, F12 on Windows/Linux)
  3. Click the Application tab (Chrome/Edge) or Storage tab (Firefox)
  4. In the left sidebar, expand Cookies and click on https://www.trainingpeaks.com
  5. Find the cookie named Production_tpAuth
  6. Double-click its Value column and copy the entire string

3. Add to Claude Desktop

Open your Claude Desktop config file:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json
  • Linux: ~/.config/Claude/claude_desktop_config.json

Note: If this file doesn't exist yet (first time configuring an MCP server), create it yourself. On macOS, the Claude folder inside Application Support should already exist if you've opened Claude Desktop at least once — you just need to create the claude_desktop_config.json file inside it.

First, find the full path to uvx:

which uvx

This will output something like /Users/yourname/.local/bin/uvx.

Then add this to your config (replace the command path and your_cookie_value):

{
  "mcpServers": {
    "trainingpeaks": {
      "command": "/Users/yourname/.local/bin/uvx",
      "args": ["tp-mcp-server"],
      "env": {
        "TP_AUTH_COOKIE": "your_cookie_value"
      }
    }
  }
}

Important: You must use the full absolute path to uvx (not just "uvx"). Claude Desktop has a limited PATH and won't find it otherwise.

4. Restart Claude Desktop

Fully quit and reopen Claude Desktop. You should see "trainingpeaks" listed as a connected MCP server (look for the hammer icon).

That's it — no cloning, no virtual environments. uvx automatically downloads and runs the package from PyPI.


Alternative: Install from source

If you want to modify the code or contribute:

Prerequisites

  • Python 3.12+
  • uv (recommended) or pip

Steps

git clone https://github.com/banananovej-chuan/tp-mcp-server.git
cd tp-mcp-server
uv venv --python 3.12
uv pip install .

Get your cookie (see step 2 above), then configure the environment:

cp .env.example .env
# Edit .env and paste your cookie value

For Claude Desktop, use the absolute path to the venv Python:

{
  "mcpServers": {
    "trainingpeaks": {
      "command": "/absolute/path/to/tp-mcp-server/.venv/bin/python",
      "args": ["-m", "tp_mcp_server"],
      "env": {
        "TP_AUTH_COOKIE": "your_cookie_value"
      }
    }
  }
}

Important: The command path must be an absolute path. On macOS/Linux it starts with /, on Windows use the full path like C:\\Users\\yourname\\tp-mcp-server\\.venv\\Scripts\\python.exe. Do not use ~ or relative paths.

Example Queries

Once connected in Claude Desktop, try:

  • "What's my current fitness level?"
  • "Show my planned workouts for the next 2 weeks"
  • "Show my training load trend for the last 3 months"
  • "Analyze my last bike workout"
  • "What are my power PRs?"
  • "How is my training zone distribution this month?"
  • "Compare my bike performance over the last 90 days"

Refreshing Your Auth Cookie

The TrainingPeaks auth cookie expires periodically (typically every few days to weeks). When it expires:

  1. You'll see authentication errors in Claude Desktop
  2. Re-extract the cookie from your browser (repeat Step 2 from Quick Start)
  3. Update the TP_AUTH_COOKIE value in your Claude Desktop config (and .env file if using source install)
  4. Restart Claude Desktop

Architecture

src/tp_mcp_server/
├── server.py              # FastMCP entry point
├── mcp_instance.py        # Shared MCP instance
├── config.py              # Environment config
├── api/
│   ├── client.py          # Async httpx client, token management
│   └── endpoints.py       # API URL constants
├── auth/
│   ├── storage.py         # Cookie storage (env/keyring)
│   └── browser.py         # Browser cookie extraction
├── tools/
│   ├── auth.py            # Auth status/refresh
│   ├── profile.py         # Athlete profile
│   ├── workouts.py        # Workout list/detail
│   ├── fitness.py         # CTL/ATL/TSB data
│   ├── peaks.py           # Personal records
│   └── analytics.py       # Derived analytics
├── models/
│   ├── workout.py         # Workout models
│   ├── fitness.py         # Fitness models + CTL computation
│   ├── peaks.py           # PR models
│   └── profile.py         # Profile model
└── utils/
    ├── dates.py            # Date helpers
    └── formatting.py       # Output formatting

Known Limitations

  • Internal API: TrainingPeaks has no public API. This uses the same internal API as the web app, which could change without notice.
  • Cookie auth: Requires periodic browser re-login to refresh the cookie.
  • Sport-level PRs: The /personalrecord/v2/athletes/{id}/{sport} endpoint returns 500. PRs are aggregated from individual workouts instead.
  • CTL/ATL/TSB: The API returns "NaN" for these values. They are computed locally from TSS data.
  • Rate limiting: Requests are throttled to 150ms apart to avoid hitting TP rate limits.

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

tp_mcp_server-0.2.3.tar.gz (83.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tp_mcp_server-0.2.3-py3-none-any.whl (33.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: tp_mcp_server-0.2.3.tar.gz
  • Upload date:
  • Size: 83.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for tp_mcp_server-0.2.3.tar.gz
Algorithm Hash digest
SHA256 a81f687d75f89a384eb9f5d9c30f50f57f2514059b87cd39f18c7ce9370129ba
MD5 4d54d007ed0a24120109b52129178e02
BLAKE2b-256 8350f654c276ad09365ebf0d0048a466c8b37dd242f1a01c41df0491223e3920

See more details on using hashes here.

File details

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

File metadata

  • Download URL: tp_mcp_server-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 33.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for tp_mcp_server-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 be4257e1c78962bd37959b222083b82c971e898ba1e72692a04760961aee6f8c
MD5 5ddbae5f872d9540c647abfc35107fdf
BLAKE2b-256 8f5139538a0b67205a3ae8f51fc15025f15268bfc93a01f34c566de968c3b2d9

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