Swiggy Deal Finder
Finds the cheapest nearby option for a dish on your own Swiggy account, ranked by final post-coupon payable amount.
README
Swiggy Deal Finder
Swiggy Deal Finder is an MCP connector that finds the cheapest nearby option for a dish on your own Swiggy account, ranked by final post-coupon payable amount.
It is designed for discovery only:
- no order placement
- read + controlled cart mutation for pricing probes
- automatic cart cleanup after each pricing probe
What this project does
Given a dish and a selected saved delivery address, the connector:
- Finds open restaurants within 7 km.
- Matches menu items for the requested dish.
- Prices top candidates by probing Swiggy cart + coupon application.
- Returns ranked options by:
- lowest final payable amount (
to_pay) - highest rating as tie-breaker
- lowest final payable amount (
The MCP server exposes these tools:
get_locations()list_dish_variants(dish, address_id, category?)find_deals(dish, address_id, top_n=5, portion="regular", category?)
Architecture overview
Core modules (src/swiggy_deal_finder):
server.py
MCP entrypoint (FastMCP), tool definitions, lifespan-managed persistent Swiggy client.live_client.py
Real Swiggy adapter overmcp-remote(spawned vianpx), wraps MCP tool calls.service.py
Orchestration pipeline (DealFinder) for candidate discovery → pricing → ranking.candidates.py
Restaurant/menu discovery, dish-token matching, distance/open filters, portion filtering.pricing.py
Cart safety guard + coupon probe cycle. Handles empty-cart precondition and cart flush.ranking.py
Final ordering logic (final_to_payasc, rating desc).swiggy_client.py
Protocol and pure parsers for Swiggy responses.models.py
Pydantic domain models.main.py
Minimal FastAPI app (/health) for service health checks.
Safety invariants
The project enforces a few critical rules:
- Never places an order.
- Refuses pricing if the cart is already non-empty.
- Never flushes a cart it did not create.
- Always flushes probe cart items after pricing completes (or on failure path after entry).
- Uses fresh cart reads for truth after coupon application.
Prerequisites
- Python
>= 3.14(as defined inpyproject.toml) uvfor environment management- Node.js /
npx(used to spawnmcp-remote) - A Swiggy account with saved delivery addresses
Setup
-
Install dependencies:
uv sync --dev -
Create environment file:
cp .env.example .env -
Fill required values in
.env:- Swiggy MCP/OAuth values (as available in your environment)
- Vertex/Gemini values for model access
APP_SECRET_KEY(required)
-
Validate connectivity:
uv run python scripts/check_env.py
Running locally
1) FastAPI health app
uv run uvicorn swiggy_deal_finder.main:app --reload
Health endpoint:
GET /health→{"status":"ok"}
2) MCP server (for Claude Desktop / MCP clients)
uv run python -m swiggy_deal_finder.server
This starts the MCP connector and keeps one persistent authenticated Swiggy session for tool calls.
Typical MCP usage flow
- Call
get_locations()and choose anaddress_id. - If dish is generic (e.g.
dosa,pizza,biryani), calllist_dish_variants(...)first. - Call
find_deals(...)with the selected specific dish. - Present ranked results to the user.
Notes:
categoryshould be a broad cuisine/category term when dish search is too specific.portion="regular"excludes mini/half-style servings unless user explicitly asks.
Scripts
Repository scripts:
scripts/check_env.py
Validates env load + Swiggy MCP reachability + Vertex/Gemini reachability.scripts/smoke_live.py
Read-only live smoke test against Swiggy MCP bridge.scripts/demo.py
Runs the full deal-finder engine from CLI.scripts/check_server.py
End-to-end MCP server check by spawning connector and invoking tools.
See also: DEMO.md for local Claude Desktop demo wiring details.
Development commands
Lint:
uv run ruff check .
Tests:
uv run pytest
Testing scope
Tests in tests/ cover:
- parser and config behavior
- candidate filtering and matching
- pricing/cart guard behavior
- ranking logic
- server tool behavior
- live-client adapter contract assumptions
Troubleshooting
-
uv: command not found
Installuvfrom https://docs.astral.sh/uv/installation/ and ensure it is in your PATH. -
No results for a specific dish phrase
Retry with a broadercategory(e.g.dosa,biryani,roll) and then match exact dish via menu scan. -
Cart-not-empty response from
find_deals
Clear your cart in Swiggy app before pricing; this is a deliberate safety check. -
No saved addresses
Add delivery addresses in your Swiggy app first.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.