loading…
Search for a command to run...
loading…
Enables AI assistants to query the full FAOSTAT API for global food and agriculture statistics, allowing natural-language questions about crop production, trade
Enables AI assistants to query the full FAOSTAT API for global food and agriculture statistics, allowing natural-language questions about crop production, trade, food security, emissions, and more.
Query UN food and agriculture statistics with AI — powered by the Model Context Protocol
Version PyPI MCP Registry Python 3.10+ MCP Compatible License: MIT
An MCP (Model Context Protocol) server that exposes the full FAOSTAT API as tools for AI assistants. Connect any MCP-compatible client — Claude, Cursor, Windsurf, Zed, or your own agent — to the world's most comprehensive database of food, agriculture, fisheries, forestry, and nutrition statistics, covering 245 countries and territories from the United Nations Food and Agriculture Organization (FAO).
Keywords: FAOSTAT, MCP server, Model Context Protocol, AI agriculture data, FAO statistics, food security AI, agricultural data Python, UN data, crop production statistics, Claude, Cursor, Windsurf
Researchers, data journalists, policy analysts, and developers can ask natural-language questions and get answers directly from FAOSTAT — without writing a single API call. Your AI assistant handles domain discovery, filtering, and interpretation automatically.
Who is this for?
FAOSTAT is the statistical database of the United Nations Food and Agriculture Organization (FAO). It is the world's most comprehensive freely available source of data on food and agriculture, covering:
Data spans from 1961 to the present, across 245 countries and territories, in multiple languages.
The Model Context Protocol is an open standard that lets AI assistants call external tools at runtime. This server registers all FAOSTAT API endpoints as discoverable tools — your AI assistant automatically selects and chains the right calls when you ask a question.
faostat_setup — store credentials once, never touch a config file againfaostat_search_codes — agents ask before guessing ambiguous codesListed on the official MCP Registry — discoverable directly from Claude Desktop, Cursor, and any MCP-compatible client.
# Install with pip or uvx (no virtual env needed):
pip install faostat-mcp
uvx faostat-mcp
git clone https://github.com/berba-q/faostat-mcp.git
cd faostat-mcp
pip install -e .
Easiest — use the faostat_setup tool (no config files needed):
Once the server is running and connected to your AI client, ask your assistant:
"Call faostat_setup with my FAOSTAT username and password."
The tool validates your credentials against the API, then stores them securely in your system keychain (macOS/Windows) or ~/.config/faostat-mcp/credentials.json (Linux/Docker). All subsequent sessions authenticate automatically — no env vars or .env file required.
Alternative — environment variables (CI/CD, Docker, advanced):
cp .env.example .env
# Edit .env:
# FAOSTAT_API_TOKEN=your_token_here ← API token, OR
# FAOSTAT_USERNAME=your_email ← username + password
# FAOSTAT_PASSWORD=your_password
Register for a free FAOSTAT API account at the FAOSTAT Developer Portal.
The server works without Redis (SQLite disk cache is used instead). For shared or high-volume setups, launch Redis via Docker:
docker run -p 6379:6379 -it redis/redis-stack:latest
Then set REDIS_HOST_IP_ADDRESS, REDIS_HOST_PORT_NUMBER, and REDIS_DATABASE in .env.
mcp dev faostat_mcp/server.py
Opens a browser UI at http://localhost:5173 where you can browse and test all 21 tools interactively.
python -m faostat_mcp.server
# or, using the installed script:
faostat-mcp
The server uses a 3-tier cache to minimise redundant API calls. FAOSTAT data updates at most daily, so most repeated queries are served instantly.
| Tier | TTL | Scope | Notes |
|---|---|---|---|
| In-memory | 20 min | Current session | Fastest; reset on server restart |
| SQLite disk | 24 h | Cross-session | ~/.cache/faostat-mcp/cache.db; no extra infra |
| Redis | 30 min | Multi-user shared | Optional; set REDIS_* env vars to enable |
Cache lookup order: memory → disk → Redis → API call. A disk or Redis hit promotes the value to memory for the rest of the session.
To disable the disk cache (e.g. on a read-only filesystem), set FAOSTAT_DISK_CACHE=false.
The server speaks standard MCP over stdio, so it works with any compatible client.
{
"mcpServers": {
"faostat": {
"command": "uvx",
"args": ["faostat-mcp"]
}
}
}
{
"mcpServers": {
"faostat": {
"command": "python",
"args": ["-m", "faostat_mcp.server"],
"cwd": "/path/to/faostat-mcp",
"env": {
"FAOSTAT_API_TOKEN": "your_token_here"
}
}
}
}
Add one of the blocks above to:
~/Library/Application Support/Claude/claude_desktop_config.json%APPDATA%\Claude\claude_desktop_config.jsonRestart Claude Desktop — faostat will appear in the tools panel.
Add the block to .cursor/mcp.json in your project root, or to your global Cursor MCP settings. See the Cursor MCP docs for details.
Any client that supports MCP stdio servers accepts the same config shape. Consult your client's documentation for the config file location.
Once connected, ask your AI assistant questions like:
| Domain | Example Question |
|---|---|
| Crop production | "What were the top 10 wheat-producing countries in 2022?" |
| Food security | "Show me food security indicators for Ethiopia from 2015 to 2020" |
| Trade | "Which countries are most dependent on food imports?" |
| Yield comparison | "Compare maize yields between the USA and Brazil over the last decade" |
| Emissions | "What are greenhouse gas emissions from agriculture in Sub-Saharan Africa?" |
| Discovery | "What agricultural datasets does FAOSTAT have for trade?" |
Your AI assistant will automatically:
faostat_list_groups or faostat_groups_and_domains to find the right domainfaostat_search_codes to look up a code by name — if multiple codes match (e.g. "production" matches both Production and Gross Production Index), the assistant pauses and asks you to choose before proceedingfaostat_get_data or faostat_get_rankings with the confirmed codes| Tool | Description |
|---|---|
faostat_ping |
Check API health |
faostat_list_groups |
List all data groups |
faostat_groups_and_domains |
Full domain tree |
faostat_list_domains |
Domains within a group |
faostat_get_dimensions |
Available filters for a domain |
faostat_get_codes |
Browse all country/item/element filter codes |
faostat_search_codes |
Search codes by name — returns requires_confirmation=true when multiple codes match, forcing the agent to ask you before proceeding |
faostat_get_definitions |
Domain definitions |
faostat_get_definitions_by_type |
Definitions by type |
faostat_definition_types |
All definition types |
faostat_get_metadata |
Full domain metadata |
faostat_get_metadata_print |
Printable metadata |
| Tool | Description |
|---|---|
faostat_get_data |
Fetch actual statistics |
faostat_get_datasize |
Estimate query result size before fetching |
faostat_get_rankings |
Top-N country rankings |
faostat_get_report_data |
Report data |
faostat_get_report_headers |
Report column headers |
faostat_list_bulk_downloads |
Bulk download file listing |
faostat_list_documents |
Related documents |
| Tool | Description |
|---|---|
faostat_setup |
First-time setup — validate and store credentials securely; subsequent sessions authenticate automatically |
faostat_refresh_token |
Manually refresh the API access token |
faostat-mcp/
├── pyproject.toml
├── smithery.yaml ← Smithery MCP registry manifest
├── .env.example
├── mcp_config_example.json ← AI config snippet
└── faostat_mcp/
├── server.py ← FastMCP server + all 21 tool definitions
└── client.py ← HTTP client, rate limiting, 3-tier cache, credential storage
The FAOSTAT API uses two different code systems: filter codes (used in query parameters) and display codes (shown in response data and bulk CSVs). Always use filter codes from faostat_get_codes when calling faostat_get_data.
Area, item, and year codes are the same for both. Only element codes differ:
| Filter Code | Display Code | Element |
|---|---|---|
2312 |
5312 |
Area harvested |
2413 |
5412 |
Yield |
2510 |
5510 |
Production quantity |
2111 |
5111 |
Stocks |
2313 |
5320 |
Producing animals / slaughtered |
| Filter Code | Display Code | Element |
|---|---|---|
2610 |
— | Import quantity |
2620 |
— | Import value |
2910 |
— | Export quantity |
2920 |
— | Export value |
| Filter Code | Display Code | Element |
|---|---|---|
6120 |
— | Value |
6210 |
— | Confidence interval |
Always call
faostat_get_codes(dimension_id='element', domain_code=...)before querying data. Filter codes vary by domain and cannot be inferred from display codes.
# WRONG — uses display code 5510, returns empty data
faostat_get_data('QCL', area='2', item='515', element='5510', year='2024')
# CORRECT — uses filter code 2510, returns data
faostat_get_data('QCL', area='2', item='515', element='2510', year='2024')
https://faostatservices.fao.org/api/v1)..env.example for TTL and size configuration.~/.cache/faostat-mcp/cache.db and defaults to 24 h TTL with a 1,000-entry LRU cap. Set FAOSTAT_DISK_CACHE=false to disable.Want guided analysis workflows on top of this server? Check out FAOSTAT Skills — 9 platform-agnostic AI skills for country profiles, commodity briefings, trade analysis, climate assessments, data visualization, and more. Works with Claude Code, OpenAI Codex, and any AI assistant that supports the SKILL.md format.
Thanks to everyone who has contributed to this project.
| Contributor | Contribution |
|---|---|
| berba-q | Project author — API client, MCP tool layer, response formatting |
| Tohokantche | Hybrid caching — in-memory (dict + min-heap TTL) and Redis tiers with graceful fallback |
Contributions are welcome — see CONTRIBUTING.md for guidelines.
If you use this tool in academic work or research, please cite it:
Plain text:
Obli-Laryea, G., & Contributors. (2026). FAOSTAT MCP Server: AI-assisted access to FAOSTAT (v1.2.2) [Computer software]. https://github.com/berba-q/faostat-mcp
BibTeX:
@software{faostat_mcp,
author = {Obli-Laryea, Griffiths and {Contributors}},
title = {FAOSTAT MCP Server: AI-assisted access to UN food and agriculture statistics},
year = {2026},
url = {https://github.com/berba-q/faostat-mcp},
version = {1.2.2}
}
See the Contributors section for a full list of authors.
When citing the underlying FAOSTAT data, use the FAO's recommended format with the specific domain:
FAO, {year}. FAOSTAT: {Domain Name}, http://www.fao.org/faostat/en/#data/{domain_code}
For example:
FAO, 2026. FAOSTAT: Crops and Livestock Products, http://www.fao.org/faostat/en/#data/QCL
FAO, 2026. FAOSTAT: Emissions Totals, http://www.fao.org/faostat/en/#data/GT
See CHANGELOG.md for a full history of changes, generated automatically from conventional commits.
If you fork or star this repo, suggested topics: mcp, faostat, model-context-protocol, ai-tools, agriculture, food-security, fao, un-data, python, llm, unfao, undata
Run in your terminal:
claude mcp add faostat-mcp-server -- npx Security
Low riskAutomated heuristic from public metadata — not a security guarantee.