Gives your agent read access to Eight Sleep pod data: sleep trends with nightly scores, temperature schedules, alarms, and adjustable base status. Built on top of the private mobile API endpoints (auth-api, client-api, app-api), so credentials stay local and nothing hits a third-party proxy. Write operations like setting heating level or snoozing alarms are gated behind an explicit flag you toggle during setup. Ships with a workflow tool that normalizes sleep context into the delx-wellness format so other health connectors can read it without knowing Eight Sleep's schema. Useful if you want LLM-driven sleep analysis or want to wire pod controls into a broader wellness automation stack without reverse-engineering OAuth yourself.
⚡ One-command install with Delx Wellness for Hermes:
npx -y delx-wellness-hermes setup— preconfigures this connector alongside the rest of the wellness catalog.Or wire it standalone into Claude Desktop / Cursor / OpenClaw / any MCP client — see the install section below.
Local-first MCP server that connects AI agents to your Eight Sleep pod — sleep sessions, temperature program, alarms, adjustable base — with an explicit mutation gate for write actions.
Unofficial project. Not affiliated with, endorsed by, or supported by Eight Sleep, Inc. Eight Sleep is a trademark of its respective owner. Use this only with your own Eight Sleep account.
Eight Sleep does not publish a stable public API. This package talks to the same private endpoints (auth-api.8slp.net, client-api.8slp.net, app-api.8slp.net) the mobile app uses, following the path well documented by upstream community projects (lukas-clarke/eight_sleep, mezz64/pyEight, steipete/eightctl).
Part of Delx Wellness — a registry of local-first wellness MCP connectors.
If this connector helps your agent workflow, please star the repo. Stars make the project easier for other AI builders to discover and help Delx keep shipping local-first wellness infrastructure.
Eight Sleep ships great sleep telemetry — nightly score, presence intervals, tnt, smart-temperature schedule — but it lives inside a closed iOS/Android app with no public API. Bringing it into your agent today means reverse-engineering OAuth, juggling token refresh, normalizing endpoint shapes, and handling timezone quirks.
This package does all of that locally, exposes Eight Sleep through the Model Context Protocol, and lets any MCP-compatible agent read your sleep context (and write pod commands, if you opt in) with one config snippet. Credentials and tokens stay on your machine.
npx -y eight-sleep-mcp-unofficial setup # interactive: email + password
npx -y eight-sleep-mcp-unofficial login # persists the auth token
npx -y eight-sleep-mcp-unofficial doctor # verifies you're ready
Then add this to your MCP client config:
{
"mcpServers": {
"eight_sleep": {
"command": "npx",
"args": ["-y", "eight-sleep-mcp-unofficial"]
}
}
}
For Claude Desktop, run setup --client claude and the snippet is written for you.
Three things to ask first:
Use eight_sleep_connection_status to check setup, then run eight_sleep_get_me.
Tell me what device you find.
Call eight_sleep_get_trends for the last 7 days, response_format=json.
What's my best night and worst night, and why?
Call eight_sleep_get_temperature. Summarize the current smart schedule
(bedtime, initial sleep, final sleep) and tell me if I should tune it.
This package talks to the Eight Sleep mobile-app API. It does not access continuous biometric sensor streams or BLE.
| Data | Tool | Source |
|---|---|---|
| User & device | eight_sleep_get_me, eight_sleep_get_user, eight_sleep_get_current_device | client-api.8slp.net /users/... |
| Temperature program | eight_sleep_get_temperature | app-api.8slp.net /v1/users/{id}/temperature |
| Sleep trends | eight_sleep_get_trends | client-api.8slp.net /users/{id}/trends |
| Alarms | eight_sleep_get_alarms | app-api.8slp.net /v2/users/{id}/alarms |
| Adjustable base | eight_sleep_get_base | app-api.8slp.net /v1/users/{id}/base |
| Tool | What it does |
|---|---|
eight_sleep_nightly_summary | Multi-night summary: best night, worst night, mean score, nights under 70 / over 85 — one call instead of post-processing raw get_trends. |
eight_sleep_wellness_context | Returns a normalized delx-wellness-context/v1 payload so other Delx Wellness tools (Nourish, Exercise Catalog, Telegram coaches) can read sleep context without knowing the Eight Sleep API. |
Off by default. To enable, re-run setup with --allow-mutations or set EIGHT_SLEEP_ALLOW_MUTATIONS=true.
| Action | Tool |
|---|---|
| Set heating level | eight_sleep_set_temperature |
| Turn side on/off | eight_sleep_set_side |
| Toggle away mode | eight_sleep_set_away_mode |
| Snooze alarm | eight_sleep_snooze_alarm |
| Dismiss alarm | eight_sleep_dismiss_alarm |
When the gate is off, mutation tools return an explicit mutations disabled error so agents can detect it and ask the user to opt in.
~/.eight-sleep-mcp/config.json with chmod 600.~/.eight-sleep-mcp/tokens.json with chmod 600.EIGHT_SLEEP_PRIVACY_MODE:
summary — minimal fields only.structured (default) — keeps useful fields but redacts identifiers.raw — full upstream payload (debugging only).Call eight_sleep_privacy_audit at any time to inspect the current posture without exposing secrets.
| Var | Purpose |
|---|---|
EIGHT_SLEEP_EMAIL | Account email. |
EIGHT_SLEEP_PASSWORD | Account password. |
EIGHT_SLEEP_ALLOW_MUTATIONS | true to enable write tools. |
EIGHT_SLEEP_PRIVACY_MODE | summary / structured / raw. |
EIGHT_SLEEP_CACHE | sqlite to enable on-disk response cache. |
EIGHT_SLEEP_TOKEN_PATH | Override token storage path. |
EIGHT_SLEEP_CLIENT_ID / EIGHT_SLEEP_CLIENT_SECRET | Override Android-app credential defaults (advanced). |
Eight Sleep changes mobile-app endpoints without notice. This connector tracks upstream community projects (lukas-clarke/eight_sleep, steipete/eightctl, mezz64/pyEight) for breakage signals. If a tool starts returning 4xx unexpectedly, check those repos and the project issues for the latest known-good shape.
lukas-clarke/eight_sleep — Home Assistant integration, most current reference for V2 endpoints.mezz64/pyEight — original Python library; auth + endpoint discovery.steipete/eightctl — CLI variant with extracted client credentials.LiamSnow/opensleep — full open-source firmware (deeper than this MCP goes).MIT — see LICENSE.
EIGHT_SLEEP_EMAILEight Sleep account email. Optional when configured with eight-sleep-mcp-server setup.
EIGHT_SLEEP_PASSWORDsecretEight Sleep account password. Prefer the setup command so this secret is stored in ~/.eight-sleep-mcp/config.json (chmod 600) instead of MCP client config.
EIGHT_SLEEP_ALLOW_MUTATIONSSet to true to enable write tools (set_temperature, set_side, set_away_mode, snooze/dismiss alarm). Default false (read-only).
EIGHT_SLEEP_PRIVACY_MODEOptional payload mode: summary, structured, or raw. Defaults to structured.
EIGHT_SLEEP_CACHEOptional SQLite cache toggle. Set to true or sqlite to enable.
EIGHT_SLEEP_TOKEN_PATHOptional local token path. Defaults to ~/.eight-sleep-mcp/tokens.json.
EIGHT_SLEEP_CLIENT_IDOptional override for the Android-app client_id default.
EIGHT_SLEEP_CLIENT_SECRETsecretOptional override for the Android-app client_secret default.