Food402
An MCP server that enables AI assistants to order food from TGO Yemek by browsing restaurants, managing carts, and completing checkouts. It allows users to handle address selection and order tracking directly through natural language interactions.
README
Food402 MCP Server
An MCP (Model Context Protocol) server that enables AI assistants to order food from TGO Yemek. Simply chat with your AI assistant to browse restaurants, build your order, and complete checkout. Works with Claude, ChatGPT (Developer Mode), and Codex CLI via MCP.
Local MCP Server (npm package)
Claude Desktop
Add to your Claude Desktop config (~/Library/Application Support/Claude/claude_desktop_config.json on macOS):
{
"mcpServers": {
"food402": {
"command": "npx",
"args": ["-y", "food402"],
"env": {
"TGO_EMAIL": "your-email@example.com",
"TGO_PASSWORD": "your-password"
}
}
}
}
Replace your-email@example.com and your-password with your TGO Yemek credentials.
Claude Code
For project-specific installation with Claude Code:
npm install food402
This automatically adds food402 to your .mcp.json. Open the file and update your credentials:
{
"mcpServers": {
"food402": {
"command": "node",
"args": ["./node_modules/food402/dist/src/index.js"],
"env": {
"TGO_EMAIL": "your-email@example.com",
"TGO_PASSWORD": "your-password"
}
}
}
}
Codex CLI (Terminal)
Codex reads MCP servers from your global config at ~/.codex/config.toml.
Option A: Via CLI
codex mcp add food402 --env TGO_EMAIL=your-email@example.com --env TGO_PASSWORD=your-password -- npx -y food402
Option B: Manual config
Add to ~/.codex/config.toml:
[mcp_servers.food402]
command = "npx"
args = ["-y", "food402"]
[mcp_servers.food402.env]
TGO_EMAIL = "your-email@example.com"
TGO_PASSWORD = "your-password"
Prerequisites
Account Setup Required
Before using this MCP server, you must have a TGO Yemek account with:
- TGO Yemek account - Create one at tgoyemek.com if you don't have one
- Payment card saved to your account - The checkout process requires a saved card; you cannot enter card details during ordering
- At least one delivery address saved (recommended) - You can add addresses through the MCP, but having one pre-configured makes ordering faster
Quick Start: Ordering Flow
Here's the typical workflow when ordering food through the AI assistant:
1. Select Delivery Address
"Show me my saved addresses"
"Select my home address for delivery"
2. Find Restaurants
"What restaurants are near me?"
"Search for pizza restaurants"
"Find places that serve lahmacun"
3. Browse Menu & Add Items
"Show me the menu for [restaurant name]"
"Add 2 lahmacun to my cart"
"What customization options are available for this item?"
4. Review & Checkout
"Show me my basket"
"Remove the drink from my order"
"I'm ready to checkout"
5. Place Order
"Place my order using my saved card"
Note: A browser window will open for 3D Secure verification. Complete the verification to finalize your order.
6. Track Order
"What's the status of my order?"
"Show me my recent orders"
Available Tools
| Tool | Description | Parameters |
|---|---|---|
get_addresses |
Get user's saved delivery addresses | None |
select_address |
Select delivery address (must call before ordering) | addressId |
get_restaurants |
Search restaurants near a location | latitude, longitude, page? |
search_restaurants |
Search restaurants and products by keyword | searchQuery, latitude, longitude, page? |
get_restaurant_menu |
Get restaurant's full menu | restaurantId, latitude, longitude |
get_product_details |
Get product customization options | restaurantId, productId, latitude, longitude |
get_product_recommendations |
Get "goes well with" suggestions | restaurantId, productIds[] |
add_to_basket |
Add items to cart | storeId, items[], latitude, longitude, etc. |
get_basket |
Get current cart contents | None |
remove_from_basket |
Remove item from cart | itemId |
clear_basket |
Clear entire cart | None |
get_cities |
Get list of all cities for address selection | None |
get_districts |
Get districts for a city | cityId |
get_neighborhoods |
Get neighborhoods for a district | districtId |
add_address |
Add a new delivery address | name, surname, phone, addressName, addressLine, cityId, districtId, neighborhoodId, latitude, longitude, etc. |
get_saved_cards |
Get user's saved payment cards (masked) | None |
checkout_ready |
Get basket ready for checkout with payment context | None |
set_order_note |
Set order note and delivery preferences | note?, noServiceWare?, contactlessDelivery?, dontRingBell? |
place_order |
Place order with 3D Secure (opens browser for verification) | cardId |
get_orders |
Get user's order history with status | page? |
get_order_detail |
Get detailed order info including delivery status | orderId |
Development
Repository Structure
food402/
├── src/ # MCP server (stdio transport)
│ ├── index.ts # MCP entry point with tool definitions
│ ├── auth.ts # TGO auth with token caching
│ ├── api.ts # Thin wrapper around shared/api.ts
│ └── postinstall.ts # Auto-configures .mcp.json on npm install
├── shared/ # Shared API code
│ ├── api.ts # Token-parameterized TGO API functions
│ └── types.ts # TypeScript interfaces
├── package.json # Root package (npm: food402)
├── README.md
└── CLAUDE.md
Local Server Development
# Install dependencies
npm install
# Run in development mode
npm start
# Build TypeScript
npm run build
License
MIT
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。