MCPacer
An AI-powered running coach that connects Claude to your Strava data, providing personalized training plans, progress tracking, and coaching feedback through a web dashboard.
README

An AI-powered running coach that connects Claude to your Strava data through the Model Context Protocol (MCP). Get personalized training plans, track your progress, and receive coaching feedback ā all through a web dashboard with an integrated coaching terminal. Currently, it has only been tested on Ubuntu.
ā ļø Use at your own risk. This is supposed to be a fun gadget to mess around with. That being said, I am only a hobby jogger, and it does run on top of claude code so if it messes up your computer or gets you injured it is not my fault. So take care, but also do have fun with it! I initially developped this to learn about MCP servers, and coach myself to a sub-3 hour marathon (https://www.strava.com/activities/17976045034) in a 14-ish week build starting from a 3:11:02 PR. We refined this repo during the CSAIL Agentic AI Hackathon 2026 to make it easier to use by adding UI features, a new experimental S&C tab, and improving the coaching workflow. Happy running š¤
Pete
P.S. I can highly recommend coach David or coach Kim
Features
<p align="center"> <img src="misc/figures/coaches.jpeg" alt="Coaches" width="70%" /> </p>
<p align="center"> <img src="misc/figures/dashboard_overview.png" alt="Dashboard Overview" height="280" /> Ā Ā Ā Ā <img src="misc/figures/bodymap.png" alt="Body Map" height="280" /> </p>
- Customizable Personas ā Choose from multiple coaching styles (tough love, balanced, analytical, etc.)
- Web Dashboard ā Plan overview, weekly breakdown, run detail with GPS maps and workout analysis charts
- Integrated Coaching Terminal ā Chat with your AI coach directly in the dashboard
- Training Plans ā Create, track, and adjust structured plans in YAML format
- Strava Sync ā Automatically pull activities, laps, HR, pace, and GPS data
- Plan Adherence ā Visual comparison of planned vs actual weekly mileage
- Persistent Memory ā Coach remembers your goals, injuries, patterns, and session history across conversations. This enables periodization.
- Run Digestion ā Each run gets a compact single-line summary for efficient context loading
- Body Map (PT mode) ā Discuss imbalances, pain, and tightness directly with your coach to devise a strength and conditioning plan.
Getting Started
Prerequisites
- Python 3.12+
- UV ā Python package manager
- Node.js 18+ ā Required for the web frontend (includes npm)
Install
git clone https://github.com/wernerpe/mcpacer.git
cd mcpacer
uv sync
claude mcp add strava -- uv run --directory $(pwd) mcpacer-server
cp -r skills/mcpacer ~/.claude/skills/mcpacer
This installs dependencies, registers the MCP server with Claude Code, and installs the /mcpacer coaching skill.
Launch
uv run mcpacer
This starts both the FastAPI backend and SvelteKit frontend, then opens your browser. On first launch you'll see the onboarding screen.
Onboarding
The onboarding screen walks you through connecting to Strava:
- Create a Strava API app ā Go to developers.strava.com/docs/getting-started (Section B) and create an app with:
- Application Name:
My Strava Running Coach - Website:
http://localhost - Authorization Callback Domain:
localhost
- Application Name:
- Enter your credentials ā Paste the Client ID and Client Secret into the onboarding form
- Authorize ā Click "Connect to Strava", approve in the popup, and you're in
Credentials and tokens are stored locally in .env and never leave your machine.
How It Works
Coaching Sessions
Run /mcpacer in the coaching terminal. The skill handles everything automatically:
- Loads coach memory, run context, plan context, and session logs
- Auto-loads your preferred persona
- Digests any new runs
- Opens the conversation
The coach reviews your training and responds based on your plan, recent activity, and history:
How's that groin feeling? And are we sticking to the dress rehearsal plan tomorrow or are you going to "freestyle" it again?
Accountability is everything in training. The coach posts directly to your Strava activity descriptions. Feedback is concise, references the plan, and focuses on what matters:
Plan said 4x1km @ 3:55. You did 6x1km @ 3:39. That's 50% more volume and 16s/km faster than prescribed ā in f***ing taper week. The hay is in the barn. Stop setting the damn barn on fire. I can't believe this.
Dashboard Panels
| Panel | What it shows |
|---|---|
| Plan Overview | Vertical bar chart of weekly mileage ā planned (grey) vs actual (colored) |
| Week Detail | Day-by-day breakdown with prescribed and completed runs |
| Run Detail | GPS map, stats grid, workout analysis chart with proportional lap bars, splits table |
| Coach | Integrated terminal running Claude Code |
All panel dividers are draggable (VS Code-style).
Training Plans
Plans are YAML files in training_plans/. The coach can create, modify, and track plans through MCP tools. Example structure:
plan_name: Sub-3 Marathon Build
goal_race:
date: 2026-04-04
goal_time: "2:59:59"
weeks:
- week_number: 1
total_planned_distance_km: 75
runs:
- day_of_week: Wednesday
type: workout
distance_km: 16
structure: "2.5km warmup, 5x2km @ 3:50-3:55, cooldown"
Coaching Personas
Personas live in coaching_data/personas/ as markdown files. Each defines a coaching style, tone, and behavioral rules. Available: coach (balanced), david (tough love), roland, kim, hartmann. Create your own by adding a .md file.
Architecture
MCP Tools
The coach interacts with your data through these MCP tools:
Session Context
| Tool | Description |
|---|---|
get_run_context |
Sync activities from Strava and return tiered training overview |
get_plan_context |
Active plan as compact text with current week highlighted |
get_coaching_personas |
List available persona names |
get_coaching_persona |
Load a persona's full coaching guidelines |
get_onboarding_questions |
Load the onboarding questionnaire for a new athlete (PRs, goals, constraints) |
Coach Memory
| Tool | Description |
|---|---|
read_coach_memory |
Load COACH_MEMORY.md (athlete knowledge, flags, patterns) |
update_coach_memory |
Rewrite a specific section in-place |
get_session_logs |
Load recent session summaries (auto-distills older logs) |
save_session_log |
Write session summary at end of conversation |
Activities & Runs
| Tool | Description |
|---|---|
get_activities |
Get recent activities from Strava (paginated) |
get_activities_by_date_range |
Get activities within a date range |
get_activity_by_id |
Get a single activity by Strava ID |
get_activity_streams |
Get detailed data streams (pace, HR, altitude, cadence) |
get_run_detail |
Formatted run summary with laps, HR, pace, elevation |
get_pending_digests |
Get runs needing digestion with pre-built prompts |
save_run_digest |
Save a compact digest line for a run |
add_coaching_feedback |
Post coaching feedback to a Strava activity description |
add_run_note |
Add a coach note to a run (stored locally) |
Training Plans
| Tool | Description |
|---|---|
list_training_plans |
List all saved plans |
get_training_plan |
Retrieve full plan YAML by ID |
update_plan_run |
Modify a single workout |
update_plan_week |
Update week-level metadata |
add_plan_run |
Add a new workout to a week |
remove_plan_run |
Remove a workout from a week |
add_plan_comment |
Document changes with a comment |
Memory & Context
Every session starts fresh ā no conversation history carries over. All continuity comes from structured context loaded at session start:
SESSION CONTEXT (~4000 tokens)
āāā Coach Memory .............. ~600 tok
ā Long-term athlete knowledge: goals, PRs, injuries, patterns
ā āāā Session History (one-liners for older sessions)
āāā Run Context ............... ~1400 tok
ā Tiered by age: one-liners for old weeks, full detail for recent
āāā Plan Context .............. ~1100 tok
ā Day-by-day prescriptions, current week highlighted
āāā Session Logs .............. ~200 tok
ā Last 3 session summaries for conversation continuity
āāā Persona ................... ~500 tok
Coaching tone, personality, communication style
Project Structure
mcpacer/
āāā src/mcpacer/
ā āāā server.py # MCP server entry point
ā āāā strava_client.py # Strava API client
ā āāā tools/ # MCP tool implementations
ā āāā storage/ # Run and plan persistence
ā āāā web/
ā ā āāā app.py # FastAPI app (REST + WebSocket)
ā ā āāā api.py # Dashboard REST endpoints
ā ā āāā auth.py # Strava OAuth flow
ā ā āāā pty_manager.py # Claude Code PTY management
ā ā āāā launcher.py # Starts backend + frontend
ā āāā cli/ # CLI commands
āāā web/ # SvelteKit frontend
ā āāā src/
ā āāā routes/ # Page routes
ā āāā lib/ # Svelte components
āāā coaching_data/ # Personas (tracked), memory (gitignored)
āāā training_plans/ # Plan YAML files (gitignored)
āāā run_data/ # Cached Strava data (gitignored)
āāā skills/ # Claude Code skills
CLI Commands
uv run mcpacer # Launch the web dashboard
uv run mcpacer-update-data # Sync run data from Strava
uv run mcpacer-analyze-plan # Analyze plan adherence
uv run mcpacer-generate-calendar # Generate HTML training calendar
Using as MCP Server Only
If you prefer to use the coaching tools without the web dashboard (e.g., in Claude Desktop):
claude mcp add strava -- uv run --directory /path/to/mcpacer mcpacer-server
cp -r /path/to/mcpacer/skills/mcpacer ~/.claude/skills/mcpacer
Then start a coaching session with /mcpacer in any Claude Code conversation.
Acknowledgements
This project started with a lot of inspiration from strava-mcp-server by Tomek Korbak.
License
MIT License ā see LICENSE for details.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.