A Model Context Protocol (MCP) server that enables AI assistants like Claude to interact with your MyFitnessPal data, including food diary, exercises, body measurements, nutrition goals, and water intake.
| Tool | Type | Description |
|---|---|---|
mfp_get_diary |
Read | Get food diary entries for any date |
mfp_search_food |
Read | Search the MyFitnessPal food database |
mfp_get_food_details |
Read | Get detailed nutrition info for a food item |
mfp_add_food_to_diary |
Write | Add a food item to your diary for a specific meal and date |
mfp_get_measurements |
Read | Get weight/body measurement history |
mfp_set_measurement |
Write | Log a new weight or body measurement |
mfp_get_exercises |
Read | Get logged exercises (cardio & strength) |
mfp_get_goals |
Read | Get daily nutrition goals |
mfp_set_goals |
Write | Update daily nutrition goals |
mfp_get_water |
Read | Get water intake for a date |
mfp_set_water |
Write | Log water intake for a date |
mfp_get_report |
Read | Get nutrition reports over a date range |
refresh_browser_cookies |
Utility | Extract and save session cookies from browser |
- Python 3.10+ (check with
python3 --version) - pip 21.3+ (for pyproject.toml support; upgrade with
pip install --upgrade pip) - MyFitnessPal account
- One of the following for authentication:
- Your MFP username/email and password (recommended), OR
- Chrome or Firefox with an active MyFitnessPal login session
This MCP supports multiple authentication methods:
| Method | Setup | Persistence |
|---|---|---|
| Credentials in config | Add MFP_USERNAME and MFP_PASSWORD to Claude Desktop config |
Automatic (session cached 30 days) |
| Browser cookies | Log into myfitnesspal.com in Chrome/Firefox | Until browser session expires |
# Clone the repository
git clone https://github.com/YOUR_USERNAME/myfitnesspal-mcp-python.git
cd myfitnesspal-mcp-python
# Create virtual environment (use python3.10+ on macOS/Linux)
python3 -m venv venv
# On macOS, you may need to specify version: python3.12 -m venv venv
# Activate virtual environment
source venv/bin/activate # macOS/Linux
# On Windows: .\venv\Scripts\activate
# Upgrade pip (required for pyproject.toml support)
pip install --upgrade pip
# Install the package in editable mode
pip install -e .pip install mfp-mcpNote: Option 2 requires the package to be published to PyPI. For now, use Option 1.
After installation, verify the server can start:
# With venv activated
python -m mfp_mcp.serverYou should see the server waiting for input (it communicates via stdio). Press Ctrl+C to stop.
To test authentication (optional):
MFP_USERNAME="your_email" MFP_PASSWORD="your_password" python -c "
from mfp_mcp.server import get_mfp_client
client = get_mfp_client()
print('Authentication successful!')
"| OS | Config File Location |
|---|---|
| macOS | ~/Library/Application Support/Claude/claude_desktop_config.json |
| Windows | %APPDATA%\Claude\claude_desktop_config.json |
If the file doesn't exist, create it. Add or merge the following configuration:
macOS Example:
{
"mcpServers": {
"myfitnesspal": {
"command": "/Users/yourname/myfitnesspal-mcp-python/venv/bin/python",
"args": ["-m", "mfp_mcp.server"],
"env": {
"MFP_USERNAME": "your_email@example.com",
"MFP_PASSWORD": "your_password"
}
}
}
}Windows Example:
{
"mcpServers": {
"myfitnesspal": {
"command": "C:\\Users\\YourName\\myfitnesspal-mcp-python\\venv\\Scripts\\python.exe",
"args": ["-m", "mfp_mcp.server"],
"env": {
"MFP_USERNAME": "your_email@example.com",
"MFP_PASSWORD": "your_password"
}
}
}
}macOS Example:
{
"mcpServers": {
"myfitnesspal": {
"command": "/Users/yourname/myfitnesspal-mcp-python/venv/bin/python",
"args": ["-m", "mfp_mcp.server"]
}
}
}
⚠️ Important: Use full absolute paths to the Python executable in your virtual environment. Replaceyourname/YourNamewith your actual username.
After saving the config file, completely quit and restart Claude Desktop for the changes to take effect.
In Claude Desktop, you should see a hammer icon (🔨) indicating MCP tools are available. Try asking:
"Show my MyFitnessPal diary for today"
The MCP server supports three authentication methods, tried in this order:
Set MFP_USERNAME and MFP_PASSWORD in your Claude Desktop config's env section. This is the most reliable method and doesn't require a browser.
"env": {
"MFP_USERNAME": "your_email@example.com",
"MFP_PASSWORD": "your_password"
}After successful authentication, session cookies are saved to ~/.mfp_mcp/cookies.json. These persist for 30 days, so you won't need to re-authenticate frequently.
If no credentials are provided and no stored cookies exist, the server falls back to reading cookies from Chrome or Firefox. You must be logged into myfitnesspal.com in your browser.
Your MyFitnessPal credentials in the Claude Desktop config are stored locally on your machine. The config file is only readable by your user account. However, if you're concerned about storing credentials:
- Use Option B (browser cookies) instead
- Or use a dedicated MyFitnessPal account for API access
- Session cookies are stored in
~/.mfp_mcp/cookies.jsonwith restricted permissions
Once configured, you can interact with your MyFitnessPal data through Claude:
"Show me what I ate today"
"Get my food diary for 2026-01-05"
"What meals did I log yesterday?"
"Show my weight history for the past 30 days"
"Log my weight as 232.5 pounds"
"What's my weight trend this month?"
"Search MyFitnessPal for chicken breast"
"Find nutrition info for Greek yogurt"
"Look up calories in a banana"
"Compare my nutrition goals to what I actually ate today"
"Am I on track with my protein intake?"
"How many calories do I have left today?"
"What exercises did I log today?"
"Show my workout from yesterday"
"Show my calorie intake over the past week"
"What's my average protein intake this week?"
"Generate a nutrition report for January"
myfitnesspal-mcp-python/
├── Dockerfile # Container deployment
├── pyproject.toml # Package configuration
├── README.md # This file
└── src/
└── mfp_mcp/
├── __init__.py # Package initialization
└── server.py # MCP server implementation
# Clone and enter directory
git clone https://github.com/YOUR_USERNAME/myfitnesspal-mcp-python.git
cd myfitnesspal-mcp-python
# Create virtual environment (Python 3.10+ required)
python3 -m venv venv
source venv/bin/activate
# Upgrade pip and install with dev dependencies
pip install --upgrade pip
pip install -e ".[dev]"pytestblack src/
isort src/
ruff check src/mypy src/
⚠️ Note: Docker deployment requires mounting your browser's cookie database for authentication.
# Build the image
docker build -t mfp-mcp .
# Run with Chrome cookies mounted (Linux example)
docker run -it --rm \
-v ~/.config/google-chrome:/root/.config/google-chrome:ro \
mfp-mcpProblem: Python is not in PATH or you need to specify version.
Solutions:
- On macOS/Linux, use
python3instead ofpython - Check your version:
python3 --version(must be 3.10+) - If needed, install Python 3.12 via Homebrew:
brew install python@3.12 - Then create venv with:
python3.12 -m venv venv
Problem: Your pip version is too old to support pyproject.toml builds.
Solution: Upgrade pip first:
pip install --upgrade pip
pip install -e .Problem: The server can't authenticate with your credentials or read browser cookies.
Solutions:
- If using credentials: Double-check your MFP_USERNAME and MFP_PASSWORD in the config
- If using browser cookies: Make sure you're logged into myfitnesspal.com in Chrome or Firefox
- Try logging out and back in to MyFitnessPal
- Clear browser cookies and log in fresh
- On macOS, grant Full Disk Access to Claude Desktop:
- System Settings → Privacy & Security → Full Disk Access
- Add Claude.app
Problem: Package not installed or wrong Python environment.
Solutions:
- Ensure you're using the correct Python from your virtual environment
- Reinstall the package:
pip install -e . - Verify the path in your Claude Desktop config points to the venv Python:
/path/to/project/venv/bin/python # macOS/Linux C:\path\to\project\venv\Scripts\python.exe # Windows
Problem: MCP server not connecting.
Solutions:
- Check the config file syntax (must be valid JSON - use a JSON validator)
- Use absolute paths in the configuration (no
~or relative paths) - Restart Claude Desktop completely (Cmd+Q on macOS, then relaunch)
- Check Claude Desktop logs:
- macOS:
~/Library/Logs/Claude/ - Windows:
%APPDATA%\Claude\logs\
- macOS:
Problem: Authentication works but no data returned.
Solutions:
- Verify you have data logged in MyFitnessPal for the requested date
- Check the date format (YYYY-MM-DD)
- Try a recent date where you know you have entries
Problem: VS Code/Cursor Python extension bug with venv prompt.
Solutions:
- Update the Python extension in VS Code/Cursor
- Or manually fix the venv activate script - change line ~70 in
venv/bin/activate:# Change from: PS1="("'(venv) '") ${PS1:-}" # To: PS1="(venv) ${PS1:-}"
Get food diary for a specific date.
date(optional): YYYY-MM-DD format, defaults to todayresponse_format: "markdown" or "json"
Search the MyFitnessPal food database.
query(required): Search termlimit(optional): Max results (default 10, max 50)response_format: "markdown" or "json"
Get detailed nutrition for a food item.
mfp_id(required): MyFitnessPal food ID from search resultsresponse_format: "markdown" or "json"
Add a food item to your diary for a specific meal and date.
mfp_id(required): MyFitnessPal food ID from search results (usemfp_search_foodfirst)meal(optional): Meal name - "Breakfast", "Lunch", "Dinner", or "Snacks" (default: "Breakfast")date(optional): YYYY-MM-DD format (default: today)quantity(optional): Number of servings (default: 1.0)unit(optional): Unit/serving size description (e.g., "1 cup", "100g")
Example workflow:
- Use
mfp_search_foodto find a food item and get itsmfp_id - Use
mfp_add_food_to_diarywith themfp_idto add it to your diary
Get body measurement history.
measurement(optional): "Weight", "Body Fat", "Waist", etc.start_date(optional): YYYY-MM-DD (default 30 days ago)end_date(optional): YYYY-MM-DD (default today)response_format: "markdown" or "json"
Log a body measurement for today.
measurement(optional): Type (default "Weight")value(required): Numeric value
Get exercise log for a date.
date(optional): YYYY-MM-DD (default today)response_format: "markdown" or "json"
Get daily nutrition goals.
date(optional): YYYY-MM-DD (default today)response_format: "markdown" or "json"
Update nutrition goals.
calories(optional): Daily calorie goalprotein(optional): Daily protein in gramscarbohydrates(optional): Daily carbs in gramsfat(optional): Daily fat in grams
Get water intake for a date.
date(optional): YYYY-MM-DD (default today)
Log water intake for a date.
cups(required): Number of cups of water (e.g., 2.5 for 2.5 cups). Note: MyFitnessPal uses cups as the unit (1 cup = ~237ml)date(optional): YYYY-MM-DD format (default: today)
Get nutrition report over a date range.
report_name(optional): "Net Calories", "Protein", "Fat", "Carbs"start_date(optional): YYYY-MM-DD (default 7 days ago)end_date(optional): YYYY-MM-DD (default today)response_format: "markdown" or "json"
- Credentials: If using username/password authentication, credentials are stored in your Claude Desktop config file which is only readable by your user account. Session cookies are cached in
~/.mfp_mcp/cookies.jsonfor 30 days. - Browser Cookies: As a fallback, the server can read your browser cookies to authenticate with MyFitnessPal.
- Local Only: The server runs locally on your machine via stdio transport. No data is sent to any third-party servers.
- No External Transmission: Your MyFitnessPal data is only transmitted between your computer and MyFitnessPal's servers (myfitnesspal.com).
MIT License - See LICENSE file for details.
- python-myfitnesspal - The underlying library for MyFitnessPal access
- MCP Python SDK - Model Context Protocol framework
- Anthropic - Claude and the MCP specification