Fitatu MCP Unofficial
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., "@Fitatu MCP Unofficialshow me today's meal plan"
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.

Fitatu MCP Unofficial
Unofficial Model Context Protocol (MCP) server for Fitatu. It exposes selected Fitatu account operations as typed MCP tools so an MCP client can inspect and update your own meal plan.
This project is not affiliated with, endorsed by, or sponsored by Fitatu. Fitatu credentials and account data are sensitive. Use this server only with your own account.
Features
Streamable HTTP MCP endpoint at
/mcp.Fitatu authentication through local environment variables.
Safe profile and day-plan read tools.
Food search with product and measure identifiers for follow-up mutations.
Meal item add, update, move, and remove tools.
Docker workflow for local/private deployment.
Related MCP server: fitbit-mcp
Requirements
Node.js
>=22.18.0npm
A Fitatu account
Quick Start
Install dependencies:
npm installCreate local configuration:
cp .env.example .envFill in FITATU_EMAIL and FITATU_PASSWORD in .env, then start the development server:
npm run devThe MCP endpoint is available at:
http://localhost:3000/mcpMCP Client Setup
If your MCP client supports remote Streamable HTTP servers, use this endpoint directly:
http://localhost:3000/mcpFor clients that launch MCP servers through a command, use mcp-remote:
{
"mcpServers": {
"fitatu": {
"command": "npx",
"args": ["mcp-remote", "http://localhost:3000/mcp"]
}
}
}When using a public tunnel, replace the local URL with the tunnel URL and keep the /mcp path.
Available Tools
Tool | Purpose | Mutates Fitatu data |
| Returns a safe subset of the authenticated Fitatu user profile. | No |
| Returns meals and food items for a | No |
| Searches Fitatu food catalogs for product, recipe, and measure identifiers. | No |
| Adds one or more products or recipes to a meal. | Yes |
| Updates quantity, measure, or eaten state for an existing meal item. | Yes |
| Moves a meal item to another meal, date, or both. | Yes |
| Removes an existing meal item. | Yes |
Typical workflow:
Call
get_day_plan_itemsto inspect availablemealKeyanditemIdvalues.Call
search_foodto find a matchingproductId,foodId,foodType, andmeasureId.Call a mutation tool such as
add_meal_items,update_meal_item,move_meal_item, orremove_meal_item.Call
get_day_plan_itemsagain to verify the final state.
Fitatu applies some mutations asynchronously, so a very fast follow-up read may briefly return the previous state.
Configuration
Runtime configuration is read from environment variables and validated at startup.
Variable | Required | Default | Sensitive | Description |
| Yes | none | Yes | Fitatu account email address. |
| Yes | none | Yes | Fitatu account password. |
| No |
| No | HTTP server port. |
| No |
| No |
|
| No |
| No | MCP server name. |
| No |
| No | MCP server version. |
| No |
| No |
|
Do not commit .env. The repository keeps .env.example as documentation only.
Local Development
Start the server in watch mode:
npm run devBuild the project:
npm run buildStart the built server:
npm startRun quality checks:
npm run lint
npm run format:check
npm run test:ci
npm run buildIntegration tests require valid Fitatu credentials in .env and may read or mutate data in the authenticated account.
Docker
Create .env before building the image:
cp .env.example .envFill in your Fitatu credentials in .env.
Build the Docker image:
docker build -t fitatu-mcp .The build copies .env into the image so the server can read it at runtime. Treat the built image as sensitive. Do not push it to a public registry or share it with other people.
Run the container:
docker run --name fitatu-mcp -p 3000:3000 fitatu-mcpIf a container with that name already exists, recreate it:
docker stop fitatu-mcp
docker rm fitatu-mcp
docker run --name fitatu-mcp -p 3000:3000 fitatu-mcpExposing a Local Server with Cloudflare Tunnel
When the server is running locally on port 3000, expose it through a temporary Cloudflare Tunnel:
cloudflared tunnel --url http://localhost:3000Cloudflare will print a public tunnel URL. Use that URL with the /mcp path as the MCP endpoint.
Security Notes
Use this server only with your own Fitatu account.
Do not commit Fitatu credentials, tokens, cookies, account identifiers, nutrition logs, body measurements, or profile data.
Do not expose full upstream Fitatu responses in issues, logs, tests, fixtures, or MCP responses.
Captured HTTP traffic should be used only for legitimate work with your own account and your own network traffic.
Review mutation tool calls carefully before allowing an MCP client to execute them.
Contributing
See CONTRIBUTING.md for contribution guidelines.
License
This project is licensed under the MIT License.
This server cannot be installed
Maintenance
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/AndekQR/fitatu-mcp-unofficial'
If you have feedback or need assistance with the MCP directory API, please join our Discord server