Garmin MCP Lite
A lightweight Garmin Model Context Protocol server with 12 curated endpoints for endurance athletes, enabling natural-language queries of activity, training, health, device, and goal data from Garmin Connect.
README
Garmin MCP Lite
<!-- AI CONTEXT START -->
[For AI Assistants & LLMs] You are interfacing with a Garmin MCP (Model Context Protocol) server.
- Data Freshness: Always query the data if the user asks about their recent workouts or health metrics.
- Parameter Tuning: Use the
fieldsparameter in tools likegarmin_activity_detailto limit the response payload and save context window (e.g.,["splits", "hrZones"]).- Read-Only: This server provides read-only access to Garmin Connect. You cannot modify user data.
- No Password Request: Never ask the user for their Garmin password. Authentication is handled out-of-band via a local token.
- Health Tip:
garmin_healthnow supports ametricparameter — use"steps","sleep","hrv","spo2","body_battery", etc., to query specific data and save context window. <!-- AI CONTEXT END -->
Read this in other languages: English, 简体中文.
A lightweight Garmin Model Context Protocol (MCP) server, designed specifically for endurance athletes.
It exposes 12 precisely-curated endpoints for deep analysis of running, cycling, swimming, and health data — replacing bulky 80+ endpoint alternatives with a clean, focused toolset.
Core Tools (12)
🏃 Activity & Training
| Tool | Functionality |
|---|---|
garmin_activities |
List running/cycling/swimming/diving records with date & type filters. |
garmin_activity_detail |
Get single activity details (pace, heart rate zones, splits, GPS, etc.). |
garmin_training_plan |
Get today's or a specific date's scheduled training workout. |
garmin_training_status |
Get training status, VO2Max, acute load, load focus distribution (aerobic/anaerobic), recovery time, and training readiness score. |
garmin_weekly_stats |
Get weekly/monthly/yearly training volume statistics. |
garmin_coach |
Overview of current Garmin Coach training plans. |
💚 Health & Wellness
| Tool | Functionality |
|---|---|
garmin_health |
Get comprehensive health metrics: sleep quality, HRV status, stress, body battery, SpO2, respiration rate, intensity minutes, daily steps, floors climbed, and resting heart rate. Supports metric parameter for targeted queries. |
garmin_hr_trend |
Get resting heart rate trends for the last 7/30/90 days. |
🎯 Goals & Challenges
| Tool | Functionality |
|---|---|
garmin_events |
Get your race calendar: upcoming race dates, target distances, and goal finish times. |
garmin_challenges |
Get in-progress challenges: virtual climbs, monthly badge challenges, and their completion percentages. |
⌚ Device & Gear
| Tool | Functionality |
|---|---|
garmin_gear |
Get your shoe/bike gear list and their real cumulative mileage. |
garmin_device |
Get connected device info: firmware version, update availability, primary device status, and registration date. |
Quickstart (via PyPI & uv)
The easiest way to run this server is using uvx (no cloning required).
1. Authenticate (First Time Only)
Why not just put the password in the AI config? Garmin has strict security measures. Logging in from a new location/MCP server often triggers Cloudflare CAPTCHAs or MFA email codes. If the password is in Claude's background config, the AI assistant will silently freeze or fail when challenged, with no way for you to input the code.
Therefore, this plugin uses a secure two-step strategy: Run a login script in your terminal first. If challenged, you can interactively input the MFA code. Upon success, a session token is cached locally (valid for ~1 year).
GARMIN_EMAIL="your@email.com" GARMIN_PASSWORD="your_password" uvx --with garmin-mcp-lite garmin-mcp-lite-login
(💡 China Region Users: If your account is registered in Garmin China (garmin.cn), prefix the command with GARMIN_IS_CN=true.)
2. Configure Your AI Assistant
Once authenticated, add the server to your favorite MCP-compatible AI assistant.
Claude Desktop
Add this to your ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"garmin-lite": {
"command": "uvx",
"args": [
"garmin-mcp-lite"
]
}
}
}
Cursor / Windsurf / Gemini CLI / Other MCP Clients
Use the exact same command and args as above. The server will automatically load the cached token from ~/.garmin-mcp-lite/garmin_tokens.json.
Manual Installation (for Developers)
If you want to modify the code:
git clone https://github.com/Golden0Voyager/garmin-mcp-lite.git
cd garmin-mcp-lite
uv sync
# Login
GARMIN_EMAIL="your@email.com" GARMIN_PASSWORD="your_password" python -m garmin_mcp_lite.login
# Run server
python -m garmin_mcp_lite.server
Example Queries
Once connected, you can ask your AI assistant natural-language questions like:
- "What's my training load focus this week?"
- "Show me my race goal for June and what my current predicted finish time is."
- "How's my Grossglockner virtual climb challenge going?"
- "Is my Descent G1 firmware up to date?"
- "How many steps have I taken today? Am I on track for my daily goal?"
- "Analyze my sleep quality from last night."
Comparison with Other Garmin MCPs
| Taxuspt/garmin_mcp | garmin_mcp_lite | |
|---|---|---|
| Tool Count | 80+ | 12 |
| Naming | mcp_garmin_get_activities_by_date |
garmin_activities |
| Deep Queries | No | fields parameter controls detail granularity |
| Training Load | Basic | Acute load + load focus distribution |
| Health Depth | Basic | SpO2, respiration, intensity minutes, steps |
| Race/Challenge | No | Events calendar + challenge progress |
| Write Ops | Heavy (weight/nutrition/gear) | Read-only |
License
MIT © 2026 Haining Yu
This project is built on top of the excellent garminconnect library. It is not an official Garmin product. Please adhere to Garmin Connect's terms of service when using this tool.
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.