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.2.1.tar.gz (7.5 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.2.1-py3-none-any.whl (10.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mcp_garmin-0.2.1.tar.gz
  • Upload date:
  • Size: 7.5 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.2.1.tar.gz
Algorithm Hash digest
SHA256 19cf7f9acee390157fba6a49c99621236fa289fce05805f91fa06fdb80f47d6f
MD5 d2eb6c62821dc5890bb9a8e0099633ec
BLAKE2b-256 8d08ad00bee4ba7826f7a4345c15c57d91cffcd4861cef5ba70e2f139e76ebd8

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_garmin-0.2.1.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.2.1-py3-none-any.whl.

File metadata

  • Download URL: mcp_garmin-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 10.2 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.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e6aa20ace697ecd39b9df680ecfe6f0823c90c47c2a21cf7ccdc93080cd217c8
MD5 5841896a193934618fd0ce9559c76282
BLAKE2b-256 f9fd41a1bc5ea009fdd3259a73dc2ea6750a6e262c7b79e2f74bcc0153d9bb68

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_garmin-0.2.1-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