hevy-mcp-server
Provides AI assistants with access to the Hevy fitness tracking API to log workouts, manage routines, browse exercises, and track fitness progress.
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-mcp-serverShow me my last 5 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 Fitness MCP Server
A Model Context Protocol (MCP) server that provides AI assistants with access to the Hevy fitness tracking API. This allows you to log workouts, manage routines, browse exercises, and track your fitness progress directly through AI chat interfaces.
🏋️ Features
This MCP server provides comprehensive access to Hevy's fitness tracking capabilities:
Workouts
get_workouts- Browse your workout history (paginated)get_workout- Get detailed information about a specific workoutcreate_workout- Log a new workout with exercises, sets, weights, and repsupdate_workout- Update an existing workoutget_workouts_count- Get total number of workouts loggedget_workout_events- Get workout change events (updates/deletes) since a date for syncing
Routines
get_routines- List your workout routinesget_routine- Get details of a specific routinecreate_routine- Create a new workout routine templateupdate_routine- Update an existing routine
Exercises
get_exercise_templates- Browse available exercises (includes both Hevy's library and your custom exercises)get_exercise_template- Get detailed information about a specific exercise templatecreate_exercise_template- Create a custom exercise templateget_exercise_history- View your performance history for a specific exercise
Organization
get_routine_folders- List your routine folders for organizationget_routine_folder- Get details of a specific routine foldercreate_routine_folder- Create a new routine folder
🚀 Quick Start
Prerequisites
Hevy Pro subscription - The Hevy API is only available to Pro users
Hevy API Key - Get yours at https://hevy.com/settings?developer
Cloudflare account - For deploying the MCP server
Deploy to Cloudflare Workers
Clone this repository:
git clone https://github.com/tomtorggler/hevy-mcp-server.git
cd hevy-mcp-serverInstall dependencies:
npm installSet your Hevy API key as a secret:
npx wrangler secret put HEVY_API_KEY
# Paste your API key when promptedDeploy to Cloudflare:
npm run deployYour MCP server will be available at: https://hevy-mcp-server.<your-account>.workers.dev/mcp
Local Development
Run the server locally:
npm run devThe server will be available at: http://localhost:8787/mcp
🔌 Connect to AI Clients
Claude Desktop
To connect from Claude Desktop, edit your config file (Settings > Developer > Edit Config):
{
"mcpServers": {
"hevy": {
"command": "npx",
"args": [
"mcp-remote",
"https://hevy-mcp-server.<your-account>.workers.dev/mcp"
]
}
}
}Restart Claude Desktop and you'll see the Hevy tools available.
Cloudflare AI Playground
Go to https://playground.ai.cloudflare.com/
Enter your deployed MCP server URL
Start using Hevy tools directly from the playground!
📖 Usage Examples
Creating a Workout
Once connected, you can ask your AI assistant to log workouts:
"Log a workout from today at 10am to 11am. I did bench press: 3 sets of 100kg for 10 reps, and squats: 4 sets of 120kg for 8 reps."
The assistant will:
Use
get_exercise_templatesto find the exercise IDsCall
create_workoutwith the proper structureConfirm the workout was logged successfully
Viewing Progress
"Show me my last 5 workouts"
"What's my exercise history for deadlifts?"
"Get all workout changes since January 1st, 2024"
The assistant will use get_workout_events to sync recent changes.
Managing Routines
"Create a new Push Day routine with bench press (4 sets of 8-12 reps at 100kg) and overhead press (3 sets of 10 reps at 60kg)"
The assistant will use the repRange field for exercises with rep ranges like "8-12 reps".
"Update my Upper Body routine to add pull-ups"
The assistant will use update_routine to modify existing routines.
Creating Custom Exercises
"Create a custom exercise called 'Tom's Special Cable Flyes' for chest using the cable machine"
The assistant will use create_exercise_template with the appropriate muscle groups and equipment category.
Organizing Routines
"Create a new folder called 'Summer 2024 Programs'"
The assistant will use create_routine_folder to organize your routines.
🔧 API Details
Workout Structure
When creating workouts, you can specify:
title- Name of the workout (required)startTime- When the workout started (required, ISO 8601 format)endTime- When the workout ended (required, ISO 8601 format)routineId- Optional routine ID this workout belongs todescription- Optional workout descriptionisPrivate- Whether the workout is private (optional, default: false)exercises- Array of exercises, each with:title- Exercise name from the template (required)exerciseTemplateId- Get this fromget_exercise_templates(required)supersetId- Optional superset ID (null if not in a superset)notes- Optional notes for this exercisesets- Array of set data with:type- "warmup", "normal", "failure", or "dropset" (optional)weightKg- Weight in kilograms (optional)reps- Number of repetitions (optional)distanceMeters- For cardio exercises (optional)durationSeconds- For timed exercises (optional)customMetric- Custom metric for steps/floors (optional)rpe- Rating of Perceived Exertion, 6-10 (optional)
Note: The index field for exercises and sets is automatically generated based on their position in the array.
Routine Structure
When creating routines, you can specify:
title- Name of the routine (required)folderId- Optional folder ID (null for default "My Routines" folder)notes- Optional notes for the routineexercises- Array of exercises, each with:exerciseTemplateId- Get this fromget_exercise_templates(required)supersetId- Optional superset ID (null if not in a superset)restSeconds- Rest time in seconds between sets (optional)notes- Optional notes for this exercisesets- Array of set data with:type- "warmup", "normal", "failure", or "dropset" (optional)weightKg- Weight in kilograms (optional)reps- Number of repetitions (optional)repRange- Rep range object withstartandend(optional, e.g., 8-12 reps)distanceMeters- For cardio exercises (optional)durationSeconds- For timed exercises (optional)customMetric- Custom metric for steps/floors (optional)
Important: Unlike workouts, routines do NOT use index or title fields in exercises/sets. These are generated by the API.
Time Format
All timestamps use ISO 8601 format:
2024-10-15T10:00:00Z📚 Resources
Hevy API Documentation - Official API docs
MCP Documentation - Learn about Model Context Protocol
Hevy App - The Hevy fitness tracking app
🛠️ Development
Project Structure
hevy-mcp-server/
├── src/
│ ├── index.ts # MCP server implementation with tool definitions
│ └── lib/
│ └── client.ts # Hevy API client wrapper
├── api.json # OpenAPI specification for Hevy API
├── wrangler.jsonc # Cloudflare Workers configuration
└── package.jsonAdding New Tools
To add new Hevy API capabilities:
Add the API method to
src/lib/client.tsDefine the tool in
src/index.tsinside theinit()methodUse Zod for input validation
Handle errors gracefully
Example:
this.server.tool(
"tool_name",
{
param: z.string().describe("Parameter description"),
},
async ({ param }) => {
try {
const result = await this.client.someMethod(param);
return {
content: [{
type: "text",
text: JSON.stringify(result, null, 2)
}]
};
} catch (error) {
return {
content: [{
type: "text",
text: `Error: ${error instanceof Error ? error.message : "Unknown error"}`
}]
};
}
}
);🤝 Contributing
Contributions are welcome!
How to Contribute
Fork the repository and create your branch from
mainMake your changes - add features, fix bugs, or improve documentation
Test your changes - run
npm testandnpm run type-checkFollow the code style - run
npm run formatandnpm run lint:fixSubmit a Pull Request with a clear description of your changes
Development Setup
# Clone your fork
git clone https://github.com/tomtorggler/hevy-mcp-server.git
cd hevy-mcp-server
# Install dependencies
npm install
# Copy environment variables template
cp .dev.vars.example .dev.vars
# Add your Hevy API key to .dev.vars
# Start development server
npm start
# Run tests
npm testAreas for Contribution
Add more Hevy API endpoints
Improve error handling and validation
Add more comprehensive tests
Improve documentation and examples
Report bugs or suggest features via Issues
📝 License
Unlicense - see LICENSE file for details.
This project is not affiliated with Hevy. Hevy is a trademark of Hevy Studios Inc.
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/tomtorggler/hevy-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server