Whoop MCP
Local MCP server that exposes Whoop recovery, sleep, and strain data to AI agents
Whoop MCP Server
MCP server that exposes your Whoop fitness data (recovery, sleep, strain, workouts) to Claude for use as a daily training coach.
Prerequisites
- Python 3.10+
- A Whoop Developer account with a registered application
- Your Whoop app's Client ID and Client Secret
Whoop Developer Dashboard Setup
- Go to developer.whoop.com and sign in
- Create a new application
- Set the Redirect URI to:
http://localhost:8080/callback - Enable these scopes:
read:recovery,read:cycles,read:sleep,read:profile,read:body_measurement- Note:
read:workoutandofflinemay not be available on all developer apps. The server handles missing scopes gracefully.
- Note:
- Note your Client ID and Client Secret
Installation
cd whoop-mcp
pip install -r requirements.txt
Authorization (One-Time Setup)
Export your app credentials and run the setup script:
export WHOOP_CLIENT_ID="your-client-id"
export WHOOP_CLIENT_SECRET="your-client-secret"
python scripts/setup_auth.py
This opens a browser to Whoop's authorization page. After you approve, tokens are encrypted and stored at ~/.whoop_mcp/. If the offline scope was granted, tokens refresh automatically. Otherwise, re-run this script when the token expires.
Claude Desktop / Cowork MCP Config
Add this to your Claude MCP configuration:
{
"mcpServers": {
"whoop": {
"command": "python",
"args": ["/absolute/path/to/whoop-mcp/src/whoop_server.py"],
"env": {
"WHOOP_CLIENT_ID": "your-client-id",
"WHOOP_CLIENT_SECRET": "your-client-secret"
}
}
}
}
Replace /absolute/path/to/whoop-mcp with the actual path on your machine.
Available Tools
| Tool | Description |
|---|---|
whoop_check_auth | Verify tokens are valid and not expired |
whoop_get_latest_recovery | Most recent recovery score, HRV, resting HR, SpO2 |
whoop_get_recovery_range | Recovery data for a date range |
whoop_get_latest_sleep | Last sleep session with stage breakdown |
whoop_get_sleep_range | Sleep data for a date range |
whoop_get_latest_strain | Current cycle strain, avg/max HR, kilojoules |
whoop_get_strain_range | Strain over past N days with average |
whoop_get_workouts | Workouts with sport ID, strain, HR zones |
whoop_get_profile | User profile and body measurements |
whoop_get_training_summary | Aggregated coaching snapshot (start here) |
Example Prompts
Once connected, you can ask Claude things like:
- "What was my recovery yesterday?"
- "How much strain did I accumulate last week?"
- "Am I trending toward overtraining?"
- "How has my HRV changed over the past two weeks?"
- "What were my sleep stages last night?"
- "Compare my strain to my recovery over the past 7 days."
- "Should I do a hard workout today?"
Training Coach Workflow
Start each session by calling whoop_get_training_summary for an overview of recovery status, recent strain load, sleep quality, and a training readiness assessment.
Token Storage
Tokens are stored encrypted at ~/.whoop_mcp/:
.encryption_key— Fernet encryption key (chmod 600)tokens.enc— Encrypted OAuth tokens (chmod 600)- Directory permissions: chmod 700
If token refresh fails, re-run python scripts/setup_auth.py.
İlgili Sunucular
Backup
Add smart Backup ability to coding agents like Windsurf, Cursor, Cluade Coder, etc
MCP Character Counter
Analyzes text to provide detailed character counts, including letters, numbers, and symbols.
CData Jira Service Management
A read-only server to query live Jira Service Management data via a simple MCP interface, powered by CData.
Superthread MCP Extended
A perfect drop-in replacement to the official Superthread MCP, providing way more tools. Cloudflare Workers based Remote MCP server
Google Tasks
Interact with Google Tasks to manage your to-do lists and tasks.
Excel to PDF MCP Server
Convert Excel and Apple Numbers files to PDF format.
AnkiConnect
AnkiConnect MCP server for interacting with Anki via AnkiConnect.
salary-Web
An AI-powered payroll management tool for enterprises, integrated with DingTalk.
RevenueCat to Adapty Migration
A server for migrating subscription businesses from RevenueCat to Adapty, requiring a RevenueCat API key.
Obsidian MCP Server
An MCP server that allows AI assistants to read from and write to your local Obsidian vault.