OrderFood MCP
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., "@OrderFood MCPFind sushi restaurants near me and show their top-rated items"
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.
OrderFood MCP
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.
Who this is for
AI power users who want to tell Claude or Codex "find me sushi nearby and add the best-rated option to my cart" and have it actually work
Developers exploring MCP server design for real-world consumer API integrations
Researchers studying reverse-engineered API interoperability under EU Directive 2009/24/EC Article 6
Who this is not for
Anyone looking for a fully automated "place order without touching anything" experience — order placement requires a browser payment step on both platforms and is not yet automatable (see Platform Support below)
High-volume or commercial use — this tool is designed for personal, single-account use only
Users who need a rock-solid session — Uber Eats cookies expire in 24–48 hours and require manual refresh; Thuisbezorgd tokens auto-refresh but the APIs can change without notice
Features
Tool | Description |
| Find restaurants by location, cuisine, or query |
| Get full restaurant details and menu |
| View current cart |
| Add an item to the cart with options |
| Empty the cart |
| List saved delivery addresses |
| List available payment methods |
| Place the current cart as an order |
| Get live order status |
| List past orders |
| Cancel an active order |
| Check auth + connectivity for a platform |
All tools accept platform: "ubereats" | "thuisbezorgd" as a required parameter.
Platform Support
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 | ✅ | ✅ |
|
Legend: ✅ working · ⚠️ blocked by external dependency · 🚧 stub (API not yet captured) · — not applicable
Architecture
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 platformPrerequisites
Node.js 20+
pnpm 9+
Python 3.11+ (only for API capture tooling)
Installation
git clone https://github.com/henkas/orderfood.git
cd orderfood
pnpm install
pnpm buildSetup
npx @henkas/orderfood setup --platform ubereats
npx @henkas/orderfood setup --platform thuisbezorgdCredentials 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.
Usage with Claude Code
claude mcp add orderfood -- npx @henkas/orderfoodOr if running from source:
claude mcp add orderfood -- node /path/to/orderfood/packages/mcp-server/dist/index.jsUsage with Codex
codex mcp add orderfood -- npx @henkas/orderfoodThen talk to Claude:
Find Italian restaurants near Amsterdam Centraal on ThuisbezorgdAdd a Margherita pizza from [restaurant] to my Uber Eats cartWhat's in my Thuisbezorgd cart?Show my Uber Eats payment methodsDevelopment
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 buildAPI Capture
Platform client code is based on mitmproxy captures of the real apps. To contribute new endpoint discoveries:
pip install mitmproxyFollow
tools/api-capture/README.mdto install the cert on your devicemitmproxy -s tools/api-capture/capture.pyUse the app — captured calls land in
tools/api-capture/output/{platform}/Document findings in
docs/api-reference/{platform}.md
Documentation
Install, authenticate, connect to your agent | |
Discovered endpoints and request shapes | |
Discovered endpoints and request shapes |
Contributing
See CONTRIBUTING.md.
Security
Credentials are encrypted at rest (AES-256-GCM, HKDF-SHA256 key from machine ID). See SECURITY.md for the vulnerability reporting process.
License
MIT — see LICENSE.
This server cannot be installed
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/henkas/orderfood'
If you have feedback or need assistance with the MCP directory API, please join our Discord server