whoop-mcp

whoop-mcp

Self-hosted MCP server connecting Claude to your WHOOP data via the official API, enabling queries for recovery, sleep, cycles, workouts, and profile.

Category
Visit Server

README

whoop-mcp

A self-hosted MCP server for your WHOOP data, built on the official WHOOP v2 OAuth API.

Bring your own WHOOP developer app (client id + secret). Your tokens live in storage you control — a local file or your Redis. Nothing routes through a third party, and because it uses the official API, it does not violate WHOOP's terms.

Why this exists

Approach ToS-safe Data stays yours Multi-device / scheduled
Private-API impersonation servers ❌ account risk local only depends
Hosted SaaS connectors ❌ third party holds it
whoop-mcp (this) ✅ official API ✅ your infra ✅ when deployed remotely

Tools

whoop_get_recovery, whoop_get_sleep, whoop_get_cycles, whoop_get_workouts, whoop_get_profile — each accepts start / end (ISO 8601) and limit where applicable.

Architecture

Claude ──bearer key──▶ whoop-mcp ──OAuth (your client id/secret + token)──▶ WHOOP v2 API
                          │
                          └── token store: file (local) | Redis (remote)

Two auth boundaries, kept separate:

  • Claude → your server: a bearer key you set (MCP_BEARER_KEY), also pasted into Claude's connector config.
  • Your server → WHOOP: your app's client id/secret + a stored, auto-rotating refresh token. Claude never sees your WHOOP credentials.

Refresh tokens are single-use

WHOOP rotates the refresh token on every use — each refresh returns a new one and invalidates the old. So the store must (a) write back the rotated token atomically and (b) lock so two requests can't spend the same token. Both backends handle this; it's why remote/serverless needs Redis (shared, atomic) while a single local process is fine with a file.

Prerequisites

  1. Node ≥ 20.
  2. A WHOOP app at https://developer.whoop.com:
    • Add redirect URI http://127.0.0.1:3000/callback (for the one-time auth step).
    • Enable scopes: offline, read:recovery, read:sleep, read:workout, read:cycles, read:profile, read:body_measurement.
    • Copy the Client ID and Client Secret.
npm install
cp .env.example .env   # fill in WHOOP_CLIENT_ID / WHOOP_CLIENT_SECRET

Option A — Local (file storage, Claude Desktop)

npm run auth          # opens the WHOOP consent URL; stores tokens at ~/.whoop-mcp/tokens.json
npm run build

Add to claude_desktop_config.json:

{
  "mcpServers": {
    "whoop": {
      "command": "node",
      "args": ["/absolute/path/to/whoop-mcp/dist/bin/stdio.js"]
    }
  }
}

Restart Claude Desktop and ask "What's my WHOOP recovery today?". (Works only while Desktop is open on this machine.)

Option B — Remote (Redis storage, works from web + phone + scheduled)

This is the deploy that satisfies "available everywhere + automated". Set these env vars on your host:

STORAGE=redis
UPSTASH_REDIS_REST_URL=...
UPSTASH_REDIS_REST_TOKEN=...
MCP_BEARER_KEY=<long random string>
WHOOP_CLIENT_ID=...
WHOOP_CLIENT_SECRET=...
WHOOP_REDIRECT_URI=http://127.0.0.1:3000/callback

1. Seed the token chain into Redis (run locally once, pointing at the same Upstash):

STORAGE=redis UPSTASH_REDIS_REST_URL=... UPSTASH_REDIS_REST_TOKEN=... npm run auth

2. Deploy. Two supported targets, same code:

  • Vercel (serverless): api/mcp.ts is a ready @vercel/mcp-adapter function (route POST /api/mcp). Run vercel --prod, set the env vars above in the Vercel project, and you're done. Requires STORAGE=redis.
  • Always-on container (Railway / Render / Fly): a standard long-running process — npm run build && node dist/bin/http.js, exposing POST /mcp and GET /health. No adapter needed; works with file or redis storage.

3. Add it to Claude as a custom connector: Settings → Connectors → Add custom connector → URL https://your-host/api/mcp (Vercel) or https://your-host/mcp (container), API key = your MCP_BEARER_KEY. Works across claude.ai web, mobile, and desktop, and is available to scheduled Routines.

Test locally without Claude

npm run start:http      # in one shell (needs MCP_BEARER_KEY set)
curl -s localhost:3000/health
curl -s localhost:3000/mcp -H "Authorization: Bearer $MCP_BEARER_KEY" \
  -H 'Content-Type: application/json' \
  -d '{"jsonrpc":"2.0","id":1,"method":"tools/list"}'

Open-source / share it

This is a single-tenant template: each person clones it, registers their own WHOOP app, and deploys their own instance — so everyone's data stays on their own infrastructure. No secrets are committed; all config is env vars. (A multi-tenant hosted service is a deliberately bigger project — per-user encryption, identity, tenant isolation.)

Security notes

  • Never commit .env or tokens.json (both are gitignored).
  • Treat MCP_BEARER_KEY like a password; rotate it by updating the env var and the Claude connector.
  • If you lose the stored refresh token, just re-run npm run auth.

License

MIT — see LICENSE. Uses the official WHOOP API; you must supply your own developer app credentials.

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured