loading…
Search for a command to run...
loading…
An MCP server that enables AI agents to discover restaurants and place food delivery orders on Uber Eats and Thuisbezorgd (Just Eat Takeaway). It provides tools
An MCP server that enables AI agents to discover restaurants and place food delivery orders on Uber Eats and Thuisbezorgd (Just Eat Takeaway). It provides tools for restaurant discovery and order management through normalized platform APIs.
MCP server that lets AI agents search restaurants and place food delivery orders on Uber Eats and Thuisbezorgd via 11 MCP tools.
Legal: Reverse engineering for interoperability is explicitly permitted under EU Directive 2009/24/EC Article 6. This project is personal use and open-source research — not commercial, not affiliated with Uber Eats or Just Eat Takeaway.
| Tool | Description |
|---|---|
search_restaurants |
Find restaurants by location, cuisine, or query |
get_restaurant |
Get full restaurant details and menu |
get_cart |
View current cart |
add_to_cart |
Add an item to the cart with options |
clear_cart |
Empty the cart |
get_saved_addresses |
List saved delivery addresses |
get_payment_methods |
List available payment methods |
place_order |
Place the current cart as an order |
track_order |
Get live order status |
get_order_history |
List past orders |
cancel_order |
Cancel an active order |
ping_platform |
Check auth + connectivity for a platform |
All tools accept platform: "ubereats" | "thuisbezorgd" as a required parameter.
| Capability | Uber Eats | Thuisbezorgd | Notes |
|---|---|---|---|
| Search restaurants | ✅ | ✅ | |
| Get restaurant + menu | ✅ | ✅ | TB uses SSR HTML scraping |
| Cart management | ✅ | ✅ | |
| Saved addresses | — | ✅ | UE resolves addresses on-the-fly |
| Payment methods | ✅ | ✅ | |
| Place order | ⚠️ | ⚠️ | Blocked by browser payment flow (Apple Pay / iDeal / Adyen) |
| Track order | ✅ | 🚧 | TB tracking endpoint not yet captured |
| Order history | 🚧 | 🚧 | UE: endpoint returns null — correct request params unknown; TB: not yet captured |
| Cancel order | 🚧 | 🚧 | Endpoint not yet captured |
| Health check | ✅ | ✅ | ping_platform tool verifies auth + connectivity |
Legend: ✅ working · ⚠️ blocked by external dependency · 🚧 stub (API not yet captured) · — not applicable
pnpm workspace monorepo — TypeScript 5, strict, pure ESM, Node.js 20+.
packages/
shared/ @orderfood/shared — normalized types + PlatformClient interface
ubereats-client/ @orderfood/ubereats-client — Uber Eats REST client
thuisbezorgd-client/ @orderfood/thuisbezorgd-client — Thuisbezorgd REST client
mcp-server/ @henkas/orderfood — MCP server + setup CLI
tools/
api-capture/ mitmproxy addon for capturing API traffic
docs/
api-reference/ Documented endpoints per platform
git clone https://github.com/henkas/orderfood.git
cd orderfood
pnpm install
pnpm build
npx @henkas/orderfood setup --platform ubereats
npx @henkas/orderfood setup --platform thuisbezorgd
Credentials are stored encrypted at ~/.orderfood/ (AES-256-GCM). See the Setup Guide for full step-by-step instructions including where to find the Uber Eats cookies and how the Thuisbezorgd OAuth flow works.
claude mcp add orderfood -- npx @henkas/orderfood
Or if running from source:
claude mcp add orderfood -- node /path/to/orderfood/packages/mcp-server/dist/index.js
codex mcp add orderfood -- npx @henkas/orderfood
Then talk to Claude:
Find Italian restaurants near Amsterdam Centraal on Thuisbezorgd
Add a Margherita pizza from [restaurant] to my Uber Eats cart
What's in my Thuisbezorgd cart?
Show my Uber Eats payment methods
pnpm install # install all workspace packages
pnpm typecheck # type-check all packages
pnpm test # run all tests
pnpm build # compile all packages
# Per-package
pnpm --filter @orderfood/shared test
pnpm --filter @henkas/orderfood build
Platform client code is based on mitmproxy captures of the real apps. To contribute new endpoint discoveries:
pip install mitmproxytools/api-capture/README.md to install the cert on your devicemitmproxy -s tools/api-capture/capture.pytools/api-capture/output/{platform}/docs/api-reference/{platform}.md| Setup Guide | Install, authenticate, connect to your agent |
| Uber Eats API Reference | Discovered endpoints and request shapes |
| Thuisbezorgd API Reference | Discovered endpoints and request shapes |
See CONTRIBUTING.md.
Credentials are encrypted at rest (AES-256-GCM, HKDF-SHA256 key from machine ID). See SECURITY.md for the vulnerability reporting process.
MIT — see LICENSE.
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"orderfood-mcp": {
"command": "npx",
"args": []
}
}
}