Skip to main content

MCP server to query an exported Apple Health archive (export.zip) via SQLite.

Project description

apple-health-export-mcp

CI PyPI Python License: MIT

An MCP server that lets an AI assistant query your Apple Health data — sleep, heart rate, steps, body mass, workouts, and any other metric in your export.

Apple has no live export API, so this works on a snapshot: you export your health archive once, ingest it into a local SQLite database, then the server answers queries against it. See docs/adr.md for why.

Privacy: your health data never leaves your machine and is never committed to git (.gitignore excludes *.zip / *.db).

How it works

export.zip ──(ingest, one-time ~1-3 min)──► health.db (SQLite) ──◄── MCP server queries

Setup

  1. Export your data on iPhone: Settings → Health → tap your photo → Export All Health Data. AirDrop/save the resulting export.zip.

  2. Install with uv. Installing once (rather than uvx on every launch) keeps the process tree shallow, which matters for clean shutdown — see Shutdown & process model.

    uv tool install apple-health-export-mcp
    # …or before it's on PyPI, from GitHub:
    uv tool install git+https://github.com/burakdirin/apple-health-export-mcp
    

    This puts two commands on your PATH: apple-health-export-mcp (the server) and apple-health-export-mcp-ingest.

  3. Ingest the archive (one time per new export):

    AH_DB_PATH=~/.local/share/apple-health-export-mcp/health.db \
      apple-health-export-mcp-ingest ~/Downloads/export.zip
    
  4. Add to your MCP client (e.g. Claude Code .mcp.json). The bare command starts the stdio server; point it at the DB you just built.

    Installed (recommended) — invoke the binary directly (no wrapper process):

    {
      "mcpServers": {
        "apple-health": {
          "command": "apple-health-export-mcp",
          "env": { "AH_DB_PATH": "/Users/you/.local/share/apple-health-export-mcp/health.db" }
        }
      }
    }
    

    Use an absolute path to the binary (which apple-health-export-mcp) if your client doesn't inherit your PATH.

    Or via uvx (no install; the bare package name runs the server):

    {
      "mcpServers": {
        "apple-health": {
          "command": "uvx",
          "args": ["apple-health-export-mcp"],
          "env": { "AH_DB_PATH": "/Users/you/.local/share/apple-health-export-mcp/health.db" }
        }
      }
    }
    

    claude mcp add equivalent:

    claude mcp add apple-health --env AH_DB_PATH=~/.local/share/apple-health-export-mcp/health.db \
      -- apple-health-export-mcp
    

Shutdown & process model

The server is a single process that shuts down on stdin EOF — the MCP spec's primary shutdown signal — so closing your client terminates it cleanly. Avoid extra wrapper layers (uv run … fastmcp run …): uv/uvx stay in the process tree as a parent and only conditionally forward signals, so a wrapped server can be orphaned when the client exits or you press Ctrl+C. Installing the tool and launching the binary directly (config above) gives the shallowest tree and the most reliable cleanup. fastmcp run fastmcp.json is for local dev only.

Tools

Tool Returns
list_types() Which metrics exist in your data + row counts (discovery)
get_quantity(type, start, end, agg, bucket) Daily/weekly aggregate for a numeric metric (steps, heart rate, weight…)
get_sleep(start, end) Per-night sleep stage durations
get_workouts(start, end) Workouts in the range

All query tools require a date range and return aggregates only — never raw rows (ADR-0008). get_quantity with agg="sum" auto-deduplicates parallel devices (Watch + iPhone + apps) so totals aren't inflated (ADR-0010); pass source to force one device.

Prompts

Reusable coaching workflows the client can invoke (they orchestrate the tools and reply in your language):

Prompt Purpose
daily_summary(day?) One day's snapshot
weekly_review(week_of?) Calendar week (Mon–Sun): load vs recovery + advice
monthly_summary(month?) A month in review (YYYY-MM)
yearly_summary(year?) A year's fitness trajectory (YYYY)
readiness_check() Train hard today? From sleep + recovery markers
sleep_report(start?, end?) Sleep duration, stages, consistency

Arguments are optional — they default to today / this week / this month / this year.

Development

uv sync
uv run pytest
uv run ruff check

License

MIT

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

apple_health_export_mcp-0.1.0.tar.gz (94.9 kB view details)

Uploaded Source

Built Distribution

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

apple_health_export_mcp-0.1.0-py3-none-any.whl (16.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: apple_health_export_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 94.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.26 {"installer":{"name":"uv","version":"0.11.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for apple_health_export_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 1e10d2e6e3786ae8d36328975c2a69c8523db5ad0a982fa689ce101dc2a29cd3
MD5 1c715a561a4675e90d9d8a91c60543b1
BLAKE2b-256 9366d4ff3190b358a5346e1ebfae7acfaafc448330e0bb5b983e468f83cce4e6

See more details on using hashes here.

File details

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

File metadata

  • Download URL: apple_health_export_mcp-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 16.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.26 {"installer":{"name":"uv","version":"0.11.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for apple_health_export_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 84307d6a853f0f01a0109d5522a9eca0a6d55920a98a06f4207e8342fd470505
MD5 628442ab5fb6bf2e0117d1b071d3f303
BLAKE2b-256 90ac568f3a2f75dd312d279aa13e9d6ac992f1ab79e22c004072b716fba221e8

See more details on using hashes here.

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