Canada's Food Guide
A nutrition analysis platform integrating Canada's Food Guide recipes with Health Canada's official nutrition databases.
🍲 Canada's Food Guide - MCP Server
📝 Description
The FoodGuide MCP Server bundles three powerful Health Canada resources into a single toolset for comprehensive nutritional analysis:
- Official Recipes: Search and scrape the Canada's Food Guide recipe database.
- CNF Database: Fetch exact nutrient data for ingredients from the Canadian Nutrient File API.
- DRI Calculations: Use cached Dietary Reference Intake tables to calculate demographic-specific macronutrient targets and energy requirements (EER).
| Example | Video |
|---|---|
| Find Themed recipes for a week | |
| Suggest recipes from an image of your groceries | |
| Calculate your estimated macros intake and energy requirements | |
| Calculate Macros for a recipe |
Two setup modes:
| Mode | Tools available | DB/Storage? | Best for |
|---|---|---|---|
| HTTP (remote/self-hosted) | Scraping + calculation tools (24 tools) | No | Most users -- nutrition lookups, recipe search, EER/DRI calculations |
| stdio (full) | All tools incl. SQLite (46 tools) | Yes | Power users -- recipe macro analysis, favorites, user profiles |
Check IMPLEMENTATIONS.MD if you'd like to contribute or collaborate! Always looking for suggestions!
You can use this google sheet to verify EER and CNF calculations shown in the trailer videos in the current repository.
📑 Table of Contents
📥 Installation
-
Prerequisites:
-
Clone the repository:
git clone https://github.com/Aryan-Jhaveri/mcp-foodguidecanada cd mcp-foodguidecanada -
Install dependencies:
pip3 install -r requirements.txt -
Find your Python path (needed for client config):
which python3 -
Get the absolute path to the project:
pwd
HTTP mode -- scraping + calculation, no DB (24 tools)
Start the server in a terminal and leave it running:
python3 src/server.py --transport http --port 8000
# Server running at http://0.0.0.0:8000/mcp
Then configure your client to connect to http://localhost:8000/mcp -- see Setup by Client below.
Full mode -- all tools incl. SQLite (46 tools)
Run via stdio -- no separate server process needed. Configure your client with the stdio snippets in Setup by Client.
🚀 Setup by Client
| Mode | DB tools? | Tools available |
|---|---|---|
| HTTP (start server first) | No | Scraping + calculation (24 tools) |
| stdio (full) | Yes | All tools incl. SQLite (46 tools) |
HTTP mode -- scraping + calculation (no DB)
Before configuring your client: start the server in a separate terminal:
python3 src/server.py --transport http --port 8000Keep it running while using your client.
Most clients use mcp-proxy to bridge stdio to HTTP. Claude Code connects natively.
Claude Desktop
Navigate to: Claude Desktop → Settings (⌘,) → Developer → Edit Config
{
"mcpServers": {
"FoodGuideSousChef": {
"command": "uvx",
"args": ["mcp-proxy", "--transport", "streamablehttp", "http://localhost:8000/mcp"]
}
}
}
Restart Claude Desktop after saving.
Claude Code
claude mcp add FoodGuideSousChef --transport http http://localhost:8000/mcp
Cursor
In .cursor/mcp.json (project) or ~/.cursor/mcp.json (global):
{
"mcpServers": {
"FoodGuideSousChef": {
"command": "uvx",
"args": ["mcp-proxy", "--transport", "streamablehttp", "http://localhost:8000/mcp"]
}
}
}
VS Code (GitHub Copilot)
In .vscode/mcp.json:
{
"servers": {
"FoodGuideSousChef": {
"type": "stdio",
"command": "uvx",
"args": ["mcp-proxy", "--transport", "streamablehttp", "http://localhost:8000/mcp"]
}
}
}
Full mode -- all tools incl. SQLite DB
No separate server process needed. The client launches the server directly via stdio.
Replace <python-path> and <project-path> with your actual paths from the Installation steps.
Common Python paths by system:
- Homebrew (Mac):
/opt/homebrew/bin/python3 - System Python (Mac):
/usr/bin/python3 - Anaconda:
/opt/anaconda3/bin/python3 - Linux:
/usr/bin/python3
Claude Desktop
Navigate to: Claude Desktop → Settings (⌘,) → Developer → Edit Config
{
"mcpServers": {
"FoodGuideSousChef": {
"command": "<python-path>",
"args": ["<project-path>/src/server.py"],
"cwd": "<project-path>"
}
}
}
Restart Claude Desktop after saving.
Claude Code
claude mcp add FoodGuideSousChef -- <python-path> <project-path>/src/server.py
Cursor
In .cursor/mcp.json (project) or ~/.cursor/mcp.json (global):
{
"mcpServers": {
"FoodGuideSousChef": {
"command": "<python-path>",
"args": ["<project-path>/src/server.py"],
"cwd": "<project-path>"
}
}
}
VS Code (GitHub Copilot)
In .vscode/mcp.json:
{
"servers": {
"FoodGuideSousChef": {
"type": "stdio",
"command": "<python-path>",
"args": ["<project-path>/src/server.py"],
"cwd": "<project-path>"
}
}
}
Optional flags
# HTTP mode with custom port
python3 src/server.py --transport http --port 9000 --host 0.0.0.0
# Environment variable alternative (for deployment)
MCP_TRANSPORT=http PORT=8000 python3 src/server.py
Troubleshooting
- If the server doesn't appear, check the Claude Desktop logs for error messages
- Verify Python 3.10+ is installed:
python3 --version - For HTTP mode, verify the server is running:
curl http://localhost:8000/mcp/
Made with ❤️ for Canada's Food Guide
Health Canada's Canadian Nutrient File
Health Canada's Dietary Reference Intakes
Built using FastMCPServidores relacionados
Retable
Connects AI agents to Retable for AI-assisted data management and collaboration.
MSSQL MCP Server
Connect to and interact with Microsoft SQL Server databases.
Binance Cryptocurrency MCP
Access Binance cryptocurrency market data, including prices, candlestick charts, and order books.
MySQL MCP Server
Provides read-only access to MySQL databases, allowing LLMs to inspect schemas and execute queries.
Pinecone
Connect AI tools with Pinecone projects to search, configure indexes, generate code, and manage data.
Tableau MCP Server
Interact with Tableau Server using natural language to query data and perform administrative tasks.
MCP MS SQL Server
An MCP server for executing queries on a Microsoft SQL Server database.
Shoptera Product Intelligence
Search product catalogs across thousands of Central European e-shops. Semantic search, keyword matching, GTIN/EAN lookup — via REST API or MCP. ~2,500 e-shops | ~8.5M products | 7 countries (CZ, SK, PL, HU, RO, DE, AT)
OpenTK
Provides access to Dutch parliamentary documents, debates, and member information from the Tweede Kamer via the OpenTK project.
Grist
Integrate with the Grist API to manage relational spreadsheets and data. Requires a Grist API key.