loading…
Search for a command to run...
loading…
MCP server for managing food diary, nutrition tracking, meal planning, and weight logging via the FatSecret Platform API.
MCP server for managing food diary, nutrition tracking, meal planning, and weight logging via the FatSecret Platform API.
MCP server for managing your food diary, nutrition tracking, meal planning, and weight logging via the FatSecret Platform API.
| Tool | Description |
|---|---|
fatsecret_search_food |
Search food database by name |
fatsecret_get_food |
Get full nutrition details for a food |
fatsecret_create_food_entry |
Log food to diary |
fatsecret_edit_food_entry |
Edit existing diary entry |
fatsecret_delete_food_entry |
Delete diary entry |
fatsecret_get_food_entries |
Get all entries for a date |
fatsecret_get_food_entries_month |
Monthly diary summary |
fatsecret_create_saved_meal |
Create reusable meal template |
fatsecret_add_food_to_saved_meal |
Add food to a saved meal |
fatsecret_get_saved_meals |
List saved meal templates |
fatsecret_copy_saved_meal_to_diary |
Paste saved meal into diary |
fatsecret_update_weight |
Log weight for a date |
fatsecret_get_weights_month |
Monthly weight history |
fatsecret_get_recently_eaten |
Recently logged foods |
fatsecret_copy_day |
Copy all entries between dates |
FatSecret uses separate credentials for OAuth 1.0a and OAuth 2.0:
On your developer dashboard, you'll find two credential sections:
| Section | Key | Secret | Used for |
|---|---|---|---|
| REST API OAuth 1.0 Credentials | Consumer Key | Consumer Secret | Food diary, weight, saved meals (user-level access) |
| OAuth 2.0 Credentials | Client ID | Client Secret | Food search, food details (app-level access) |
The Consumer Key and Client ID are the same value. The secrets are different — this is a common source of confusion.
For diary and weight tools, you need user-level access tokens. Run the included setup script:
FATSECRET_CLIENT_ID=your_consumer_key \
FATSECRET_CLIENT_SECRET=your_consumer_secret \
node scripts/oauth-setup.js
This will:
http://localhost:9876FATSECRET_ACCESS_TOKEN and FATSECRET_ACCESS_TOKEN_SECRETNote: The OAuth flow uses authentication.fatsecret.com (not www.fatsecret.com). You must log in with a FatSecret user account (the same one you use in the FatSecret mobile app), not your developer account.
# Required — same value, shown as "Consumer Key" / "Client ID"
export FATSECRET_CLIENT_ID="your_consumer_key"
# OAuth 1.0a Consumer Secret (from "REST API OAuth 1.0 Credentials")
# Used for: diary, weight, saved meals, recently eaten
export FATSECRET_CONSUMER_SECRET="your_consumer_secret"
# OAuth 2.0 Client Secret (from "OAuth 2.0 Credentials")
# Used for: food search, food details
export FATSECRET_OAUTH2_CLIENT_SECRET="your_oauth2_client_secret"
# User tokens from the 3-legged OAuth flow (step 3)
export FATSECRET_ACCESS_TOKEN="your_access_token"
export FATSECRET_ACCESS_TOKEN_SECRET="your_access_token_secret"
Legacy fallback: If you set FATSECRET_CLIENT_SECRET instead of the two separate secrets, it will be used for both OAuth flows. This only works if your Consumer Secret and Client Secret happen to be the same value (they aren't on most accounts).
npm install
npm run build
npm start
Add to your Claude Desktop MCP config (~/Library/Application Support/Claude/claude_desktop_config.json):
{
"mcpServers": {
"fatsecret": {
"command": "node",
"args": ["/path/to/fatsecret-mcp-server/dist/index.js"],
"env": {
"FATSECRET_CLIENT_ID": "your_consumer_key",
"FATSECRET_CONSUMER_SECRET": "your_oauth1_consumer_secret",
"FATSECRET_OAUTH2_CLIENT_SECRET": "your_oauth2_client_secret",
"FATSECRET_ACCESS_TOKEN": "your_access_token",
"FATSECRET_ACCESS_TOKEN_SECRET": "your_access_token_secret"
}
}
}
}
{
"mcpServers": {
"fatsecret": {
"command": "npx",
"args": ["-y", "github:Yurzs/fatsecret-mcp-server"],
"env": {
"FATSECRET_CLIENT_ID": "your_consumer_key",
"FATSECRET_CONSUMER_SECRET": "your_oauth1_consumer_secret",
"FATSECRET_OAUTH2_CLIENT_SECRET": "your_oauth2_client_secret",
"FATSECRET_ACCESS_TOKEN": "your_access_token",
"FATSECRET_ACCESS_TOKEN_SECRET": "your_access_token_secret"
}
}
}
}
This downloads and runs the server directly from the repo — no git clone, npm install, or npm run build needed. npx caches it locally after the first run.
Note: If you've used this before and need to pull updates, clear the npx cache first:
rm -rf ~/.npm/_npx
You can run the OAuth setup script directly too:
npx -y github:Yurzs/fatsecret-mcp-server/scripts/oauth-setup.js
Or with a one-liner using curl:
curl -sL https://raw.githubusercontent.com/Yurzs/fatsecret-mcp-server/master/scripts/oauth-setup.js | \
FATSECRET_CLIENT_ID=your_key FATSECRET_CLIENT_SECRET=your_consumer_secret node -
This starts a local server at http://localhost:9876, opens your browser, and walks you through the FatSecret authorization. The tokens are printed to the terminal when complete.
fatsecret_search_food("chicken breast")fatsecret_get_food(food_id)fatsecret_create_food_entry(food_id, "Chicken Breast", serving_id, 2.5, "lunch")fatsecret_get_food_entries("2026-05-16")fatsecret_update_weight(77.5, "2026-05-16")"Invalid IP address detected" — Add your public IP to the whitelist at https://platform.fatsecret.com. Propagation can take minutes to hours.
"Invalid signature" on OAuth 1.0a requests — You're likely using the OAuth 2.0 Client Secret instead of the OAuth 1.0a Consumer Secret. These are different values on most accounts. Check the "REST API OAuth 1.0 Credentials" section on your dashboard.
OAuth setup can't log in — The authorization page at authentication.fatsecret.com requires a FatSecret user account (the mobile app account), not your developer account. If you signed up via Apple/Google, do a password reset to set a native password.
The free Basic tier (5,000 calls/day) is sufficient for personal use. Apply for Premier Free if you want barcode scanning and autocomplete.
Выполни в терминале:
claude mcp add fatsecret-mcp-server -- npx