Skip to main content

MCP server for Garmin Connect health and fitness data

Project description

mcp-garmin

MCP server for Garmin Connect health and fitness data. Read-only access to daily health metrics, activities, workouts, and body composition via the python-garminconnect library.

Prerequisites

  • Python 3.14+
  • uv
  • A Garmin Connect account

Authentication

Garmin Connect uses email/password authentication with optional MFA. The library persists session tokens to ~/.garminconnect/garmin_tokens.json after initial login.

First-time setup

Run the interactive login command to establish tokens. This handles MFA prompts:

# Set credentials (or the CLI will prompt you)
export GARMIN_EMAIL="you@example.com"
export GARMIN_PASSWORD="your-password"

# Interactive login -- prompts for MFA if enabled
uvx mcp-garmin-login

Running the server

The MCP server requires GARMIN_EMAIL and GARMIN_PASSWORD environment variables. It reuses tokens saved by the login step and refreshes them automatically.

export GARMIN_EMAIL="you@example.com"
export GARMIN_PASSWORD="your-password"

Configuration

Claude Desktop

Add to ~/Library/Application Support/Claude/claude_desktop_config.json:

{
  "mcpServers": {
    "garmin": {
      "command": "uvx",
      "args": ["mcp-garmin"],
      "env": {
        "GARMIN_EMAIL": "you@example.com",
        "GARMIN_PASSWORD": "your-password"
      }
    }
  }
}

Claude Code

claude mcp add garmin -- uvx mcp-garmin

Set GARMIN_EMAIL and GARMIN_PASSWORD in your shell environment.

Tools

All date parameters use ISO format (YYYY-MM-DD).

Daily Health

Tool Description
get_daily_summary Steps, calories, distance, active minutes
get_heart_rates Heart rate data
get_sleep_data Sleep stages and metrics
get_stress_data Detailed stress levels
get_all_day_stress All-day stress summary
get_body_battery Body Battery (energy) levels
get_steps_data Detailed step data
get_hrv_data Heart Rate Variability
get_spo2_data Blood oxygen saturation
get_respiration_data Respiratory rate
get_training_readiness Training readiness score
get_intensity_minutes Intensity minutes
get_resting_heart_rate Resting heart rate

Activities

Tool Description
get_activities List recent activities (paginated)
get_activities_by_date Activities within a date range
get_activities_for_date All activities for a specific date
get_last_activity Most recent activity
get_activity Single activity by ID
get_activity_details Detailed metrics (laps, charts)
get_activity_splits Split/lap data
get_activity_weather Weather during activity
get_activity_hr_zones Heart rate zone distribution
get_activity_gear Equipment used
get_activity_exercise_sets Strength training sets

Workouts

Tool Description
get_workouts List saved workout templates
get_workout Single workout by ID

Body Composition

Tool Description
get_body_composition Body composition over a date range
get_weigh_ins Weight measurements over a date range

Profile & Fitness

Tool Description
get_user_profile Profile information
get_max_metrics VO2 max and fitness metrics
get_fitness_age Calculated fitness age
get_training_status Training status
get_personal_records Personal bests

Development

uv sync
uv run pytest tests/ -x -q
uv run ruff check src/ tests/
uv run pyright src/

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mcp_garmin-0.1.0.tar.gz (6.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_garmin-0.1.0-py3-none-any.whl (8.5 kB view details)

Uploaded Python 3

File details

Details for the file mcp_garmin-0.1.0.tar.gz.

File metadata

  • Download URL: mcp_garmin-0.1.0.tar.gz
  • Upload date:
  • Size: 6.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mcp_garmin-0.1.0.tar.gz
Algorithm Hash digest
SHA256 4b1abc06f451e366c090296cf6dbabced7dc77a6f77dc5ee697b0466e2e1183f
MD5 5517b7293db78476f8ddff73197128b0
BLAKE2b-256 e28623c6ec1e58742eb5f2cfabc92ca7ed05e3afdf623097a3536de5764dfb1c

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_garmin-0.1.0.tar.gz:

Publisher: release.yml on obrien-matthew/mcp-garmin

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mcp_garmin-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: mcp_garmin-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 8.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mcp_garmin-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 86d812e61871f655a9ccccaa3347ad4a5ce7b7aa38a69df5ffea09403dbb9611
MD5 b8866d4c47fba9861fdf7872499b1673
BLAKE2b-256 94252c83a94a3ca384f213dbfcfec501059192dc8a9cf77d384f25a07e06b985

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_garmin-0.1.0-py3-none-any.whl:

Publisher: release.yml on obrien-matthew/mcp-garmin

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page