The Hevy MCP server enables AI assistants to interact with the Hevy fitness tracking app API for comprehensive fitness data management:
Workout Management: Fetch, create, update, and track workouts with detailed exercise data
Routine Management: Access, create, update, and organize workout routines
Exercise Templates: Browse and retrieve both standard and custom exercise templates
Folder Organization: Create and manage folders to categorize routines effectively
Utilized for code formatting and linting in the development process of the MCP server.
Used for environment variable configuration to store the Hevy API key.
Used for version control of the MCP server codebase.
Hosts the repository for the MCP server codebase.
Provides tools for accessing and managing workout data, routines, exercise templates, and folders through the Hevy fitness app API, enabling workout tracking and fitness management capabilities.
Required as a runtime environment (v20 or higher) for running the MCP server.
Used as a package manager for installing and managing dependencies of the MCP server.
Provides badge for license information in the README.
Supported as an alternative package manager for installing and managing dependencies.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Hevy MCPshow me my last 3 workouts"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
hevy-mcp: Model Context Protocol Server for Hevy Fitness API
A Model Context Protocol (MCP) server implementation that interfaces with the Hevy fitness tracking app and its API. This server enables AI assistants to access and manage workout data, routines, exercise templates, and more through the Hevy API (requires PRO subscription).
Features
Workout Management: Fetch, create, and update workouts
Routine Management: Access and manage workout routines
Exercise Templates: Browse available exercise templates
Folder Organization: Manage routine folders
Webhook Subscriptions: Create, view, and delete webhook subscriptions for workout events
Note: HTTP transport and Docker images remain deprecated. Smithery deployment now uses the official TypeScript runtime flow (no Docker required), or you can run the server locally via stdio (e.g.,
npx hevy-mcp). Existing GHCR images remain available but are no longer updated.
Related MCP server: AgentMode
Quick start
Pick the workflow that fits your setup:
Scenario | Command | Requirements |
One-off stdio run |
| Node.js ≥ 20, Hevy API key |
Local development |
|
|
Smithery playground / deploy |
|
|
Prerequisites
Node.js (v20 or higher; strongly recommended to use the exact version pinned in
.nvmrcto match CI)pnpm (via Corepack)
A Hevy API key
Optional: A Smithery account + API key/login if you plan to deploy via Smithery
Installation
Run via npx (recommended)
You can launch the server directly without cloning:
Manual Installation
Integration with Cursor
To use this MCP server with Cursor, add/merge this server entry under
"mcpServers" in ~/.cursor/mcp.json:
Make sure to replace your-api-key-here with your actual Hevy API key.
If your mcp.json already contains other servers, do not replace the whole
file—merge the "hevy-mcp" entry into your existing "mcpServers" object.
The "hevy-mcp" key name is arbitrary. If you already have an existing config
using a different name (for example "hevy-mcp-server"), you can keep it.
If you already have an existing "mcpServers" object, merge the "hevy-mcp"
entry into it without removing other servers.
Configuration
You can supply your Hevy API key in two ways:
Environment variable (
HEVY_API_KEY)Command-line argument (
--hevy-api-key=your_keyorhevy-api-key=your_keyafter--when using pnpm scripts)
Create a .env file in the project root (you can copy from .env.sample) with the following content if using the environment variable approach:
Replace your_hevy_api_key_here with your actual Hevy API key. If you prefer the command argument approach you can skip setting the environment variable and start the server with for example:
Sentry monitoring
hevy-mcp ships with Sentry monitoring baked into the built MCP server so
that usage and errors from published builds can be observed.
The server initializes @sentry/node with a fixed DSN, release name derived
from the package version, and tracing settings
directly in the code (see src/index.ts), and wraps the underlying
McpServer with Sentry.wrapMcpServerWithSentry so requests and tool calls
are captured by Sentry automatically. The configuration uses
sendDefaultPii: false to keep Sentry's default PII collection disabled.
There is currently no built-in toggle to disable Sentry for the published
package. If you need a build without Sentry telemetry, you can fork the
repository and remove the Sentry initialization in src/index.ts.
Transport
Deploy via Smithery (TypeScript runtime)
Smithery can bundle and host hevy-mcp without Docker by importing the exported createServer and configSchema from src/index.ts.
Ensure dependencies are installed:
pnpm installLaunch the Smithery playground locally:
pnpm run smithery:devThe CLI will prompt for
HEVY_API_KEY, invokecreateServer({ config }), and open the Smithery MCP playground.Build the deployable bundle:
pnpm run smithery:buildConnect the repository to Smithery and trigger a deployment from their dashboard. Configuration is handled entirely through the exported Zod schema, so no additional
smithery.yamlenv mapping is required.
Why are Smithery’s TypeScript runtime injects its own Express bootstrap that imports these packages. Declaring them in
package.jsonensures the Smithery CLI can bundle your server successfully.
Stdio Only (Current)
As of version 1.18.0, hevy-mcp only supports stdio transport. HTTP/SSE transport has been completely removed.
hevy-mcp runs exclusively over stdio, which works seamlessly with MCP-aware clients like Claude Desktop and Cursor. The server communicates via standard input/output streams using JSON-RPC messages.
Migration from HTTP/SSE Transport
If you were using HTTP or SSE transport in an older version (< 1.18.0), you must migrate to stdio.
The HTTP/SSE transport was removed in v1.18.0 to simplify the codebase and focus on the stdio-native MCP experience. If you're encountering errors like:
"stream is not readable"when making HTTP requests"HTTP transport mode has been removed from hevy-mcp"Server messages about SSE mode on
http://localhost:3001
You are likely running an outdated build or trying to connect with an HTTP-based client. Here's how to fix it:
Steps to Migrate:
Update to the latest version:
npx -y hevy-mcp@latest # or if installed locally: pnpm install hevy-mcp@latestUpdate your client configuration to use stdio transport instead of HTTP. For example, in Cursor's
~/.cursor/mcp.json:Old HTTP-based config (no longer supported):
{ "hevy-mcp": { "url": "http://localhost:3001/sse" } }New stdio-based config (current):
{ "hevy-mcp": { "command": "npx", "args": ["-y", "hevy-mcp"], "env": { "HEVY_API_KEY": "your-api-key-here" } } }Clear any cached builds:
# If you have a local clone, rebuild pnpm run build # Or remove node_modules and reinstall rm -rf node_modules dist pnpm install pnpm run buildEnsure you're not running a custom HTTP server. If you have custom code that imports
createHttpServer(), it will now throw an error. Remove those imports and use stdio transport instead.
If you absolutely need HTTP/SSE transport, you can use version 1.17.x or earlier, but those versions are no longer maintained and contain known bugs (including the "stream is not readable" issue caused by middleware conflicts).
Usage
Development
This starts the MCP server in development mode with hot reloading.
Production
Docker (deprecated)
Docker-based workflows have been retired so we can focus on the stdio-native experience. The bundled Dockerfile now exits with a clear message to prevent accidental builds, and .dockerignore simply documents the deprecation. Previously published images remain available on GHCR (for example ghcr.io/chrisdoc/hevy-mcp:latest), but they are no longer updated. For the best experience, run the server locally via npx hevy-mcp or your own Node.js runtime.
Available MCP Tools
The server implements the following MCP tools for interacting with the Hevy API:
Workout Tools
get-workouts: Fetch and format workout dataget-workout: Get a single workout by IDcreate-workout: Create a new workoutupdate-workout: Update an existing workoutget-workout-count: Get the total count of workoutsget-workout-events: Get workout update/delete events
Routine Tools
get-routines: Fetch and format routine datacreate-routine: Create a new routineupdate-routine: Update an existing routineget-routine-by-id: Get a single routine by ID using direct endpoint
Exercise Template Tools
get-exercise-templates: Fetch exercise templatesget-exercise-template: Get a template by ID
Routine Folder Tools
get-routine-folders: Fetch routine folderscreate-routine-folder: Create a new folderget-routine-folder: Get a folder by ID
Webhook Tools
get-webhook-subscription: Get the current webhook subscriptioncreate-webhook-subscription: Create a new webhook subscriptiondelete-webhook-subscription: Delete the current webhook subscription
Project Structure
Development Guide
Code Style
This project uses Biome for code formatting and linting:
Testing
Run All Tests
To run all tests (unit and integration), use:
Note:
pnpm testruns all tests. Integration tests will fail by design ifHEVY_API_KEYis missing. If you don’t have an API key locally, use the unit test command below.
Run Only Unit Tests
To run only unit tests (excluding integration tests):
Or with coverage:
Run Only Integration Tests
To run only the integration tests (requires a valid HEVY_API_KEY):
Note: The integration tests will fail if the HEVY_API_KEY environment variable is not set. This is by design to ensure that the tests are always run with a valid API key.
GitHub Actions Configuration
For GitHub Actions:
Unit + integration tests are executed as part of the normal
Build and TestworkflowIntegration tests require the
HEVY_API_KEYsecret to be set
The workflow runs pnpm vitest run --coverage and provides HEVY_API_KEY from
repository secrets.
To set up the HEVY_API_KEY secret:
Go to your GitHub repository
Click on "Settings" > "Secrets and variables" > "Actions"
Click on "New repository secret"
Set the name to
HEVY_API_KEYand the value to your Hevy API keyClick "Add secret"
If the secret is not set, the integration tests will fail (by design).
To set up Sentry secrets for source map uploads during builds:
The build process uses Sentry's Rollup plugin to upload source maps. You need to configure three secrets:
Go to your GitHub repository
Click on "Settings" > "Secrets and variables" > "Actions"
Add the following secrets:
SENTRY_ORG: Your Sentry organization slugSENTRY_PROJECT: Your Sentry project slugSENTRY_AUTH_TOKEN: A Sentry auth token withproject:releasesscope
You can create a Sentry auth token at: https://sentry.io/settings/account/api/auth-tokens/
If these secrets are not set, the build will still succeed, but source maps will not be uploaded to Sentry.
Note: GitHub does not provide secrets to pull requests from forks by default, so
fork PRs may fail CI unless a maintainer reruns the checks with HEVY_API_KEY
available.
If CI is failing only because the fork PR is missing HEVY_API_KEY, that is
expected; maintainers may rerun the workflow with secrets enabled.
For contributors from forks: CI failures caused solely by missing HEVY_API_KEY
do not indicate a problem with your changes.
All other CI checks (build, formatting/linting, unit tests, etc.) are still expected to pass.
Only failures caused solely by missing HEVY_API_KEY on forked PRs are
considered acceptable.
Generating API Client
The API client is generated from the OpenAPI specification using Kubb:
Kubb generates TypeScript types, API clients, Zod schemas, and mock data from the OpenAPI specification.
Troubleshooting
Rollup optional dependency missing: If you see an error similar to
Cannot find module @rollup/rollup-linux-x64-gnu, set the environment variableROLLUP_SKIP_NODEJS_NATIVE_BUILD=truebefore runningpnpm run build. This forces Rollup to use the pure JavaScript fallback and avoids the npm optional dependency bug on some Linux runners.
Troubleshooting Smithery deployments
smithery.yaml: Onlyruntime,target, andenvare allowed for the TypeScript runtime. Removeentry,name, or other fields.Could not resolve "chalk"/"cors": Runpnpm installso the runtime dependencies listed inpackage.jsonare present before invoking Smithery.Failed to connect to Smithery API: Unauthorized: Log in viapnpm dlx @smithery/cli loginor setSMITHERY_API_KEYin.env.Tunnel crashes with : This is a known issue in certain
@smithery/clibuilds. Upgrade/downgrade the CLI (e.g.,pnpm add -D @smithery/cli@latest) or contact Smithery support.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
Acknowledgements
Model Context Protocol for the MCP SDK
Hevy for their fitness tracking platform and API