Provides access to Garmin Connect health data including sleep analysis, Body Battery recovery metrics, HRV tracking, and activity summaries.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Garmin Health MCP ServerSummarize my sleep and recovery trends from this past week"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Garmin Health MCP Server
Access your Garmin Connect health data directly in Claude Desktop
An MCP (Model Context Protocol) server that provides Claude Desktop with access to your Garmin wearable health data including sleep, recovery, HRV, workouts, and more.
Features
π Sleep Analysis: Hours, stages (light/deep/REM), quality scores
π Body Battery: Garmin's proprietary recovery metric (0-100)
β€οΈ HRV Tracking: Heart rate variability trends for recovery monitoring
π Activity Data: Workouts by type, calories, duration, pace
π Health Metrics: Resting heart rate, stress levels, VO2 max
π Interactive Charts: Generate beautiful HTML dashboards
π Secure: Credentials stored locally, connects only to Garmin's API
Quick Start
Prerequisites
Claude Desktop installed
Node.js 18+ and npm
Python 3.8+
Active Garmin Connect account with a connected device
Installation
Configure Claude Desktop
Edit your Claude Desktop configuration file:
macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%\Claude\claude_desktop_config.jsonLinux:
~/.config/Claude/claude_desktop_config.json
Add this MCP server configuration:
Important: Replace /absolute/path/to/garmin-health-mcp-server/ with the actual full path where you cloned this repo.
Restart Claude Desktop
Completely quit and restart Claude Desktop for the MCP server to load.
Usage
Once configured, ask Claude questions like:
"How did I sleep last night?"
"What's my Body Battery looking like this week?"
"Show me my activities from the past month"
"Is my HRV improving?"
"Generate a health dashboard for the last 30 days"
Claude will use the MCP tools to fetch your Garmin data and provide insights.
Available Tools
The server exposes these tools to Claude:
Tool | Description |
| Sleep hours, stages, quality scores |
| Recovery metric (0-100) |
| Heart rate variability trends |
| Resting, max, min heart rate |
| Workout/exercise data |
| All-day stress tracking |
| Combined health overview |
| Account and device info |
| Create interactive HTML visualizations |
Troubleshooting
"MCP server not found"
Verify the path in
claude_desktop_config.jsonis absolute (starts with/orC:\)Check that
index.jsexists at that pathEnsure you ran
npm installin the repo directory
"Authentication failed"
Run
npm run authto refresh tokensCheck your credentials in the
.envfile or environment variablesTry logging into Garmin Connect website to verify your account
"Tools not appearing in Claude"
Completely quit Claude Desktop (don't just close the window)
Check Console.app (macOS) or Event Viewer (Windows) for MCP errors
Verify Node.js is accessible:
node --versionCheck Python dependencies are installed:
python3 -c "import garminconnect"
"Missing data"
Some metrics require specific Garmin devices (e.g., Body Battery needs HRV-capable watches)
Historical data may have gaps if the device wasn't worn
New accounts may have limited history
"Too many requests" / Rate limiting
Garmin limits API requests - wait a few minutes before retrying
Use the
get_summarytool instead of calling multiple individual tools
Privacy & Security
β Credentials stored locally in
.envandclaude_desktop_config.jsonβ Session tokens cached locally and auto-refresh
β Connects only to Garmin's official API servers
β No cloud storage or third-party data sharing
β Open source - audit the code yourself
Related Projects
Clawdbot Skill - Automated health monitoring and proactive check-ins for Clawdbot
python-garminconnect - The Python library we use to access Garmin's API
Development
License
MIT Β© EversonL
Credits
Built with:
@modelcontextprotocol/sdk - MCP SDK
python-garminconnect - Garmin API wrapper
fitparse - FIT file parsing
gpxpy - GPX file handling
π Support This Project
If you find this MCP server useful, consider supporting its development:
Questions or issues? Open an issue on GitHub!