MCP server for Rappi Chile — browse stores, search products, manage cart and checkout via Claude
Project description
RappiMCP
Program : RappiMCP
Author : Bastian Girardi
Date : April 2, 2026
Purpose : Built to automate grocery and delivery purchases on Rappi Chile
through Claude — eliminating the need to manually browse the app
when you just want to tell an AI what you need and have it ordered.
An MCP (Model Context Protocol) server that gives Claude full control over Rappi Chile — browse stores, search products, manage the cart, and open checkout — all through natural language.
How it works
The server is built with FastMCP and exposes tools that Claude can call. It communicates with Rappi via their internal web API (services.rappi.cl), authenticated with tokens extracted directly from a Chrome browser session using the Chrome DevTools Protocol (CDP).
Claude ──tools──▶ rappi_mcp.py ──HTTP──▶ services.rappi.cl
│
└──CDP──▶ Chrome (auth + checkout navigation)
Setup
1. Install dependencies
pip install -r requirements.txt
2. Configure Claude Code
Add this to your Claude Code MCP settings (claude_desktop_config.json or equivalent):
{
"mcpServers": {
"RappiMCP": {
"command": "python",
"args": ["C:/path/to/RappiMCP/rappi_mcp.py"]
}
}
}
3. Authenticate
On first use, call rappi_auth to extract your Rappi credentials from Chrome and save them to .env. No manual token copying needed.
Authentication
Rappi uses rotating JWT tokens stored as browser cookies. The auth flow:
rappi_auth(use_existing_chrome=False)— launches a dedicated Chrome window at rappi.cl (on CDP port9223) and waits up to 2 minutes for you to log in- Once logged in, it reads three cookies via CDP:
rappi.data(Base64 JSON) →user_iddeviceid→device_idrappi_refresh_token→refresh_token
- Exchanges the refresh token for a fresh
access_tokenviaPOST /api/rocket/refresh-token - Writes all four values to
.env
rappi_auth(use_existing_chrome=True) (default) — attaches to an already-running Chrome with --remote-debugging-port=9223 and reads cookies immediately (you must already be logged in).
Token refresh
RappiClient handles token rotation automatically. If any API response includes the header x-refresh-token: true, it transparently refreshes both tokens and retries the request.
Environment variables
RAPPI_ACCESS_TOKEN — Bearer token for API calls
RAPPI_REFRESH_TOKEN — Used to obtain new access tokens
RAPPI_DEVICE_ID — UUID identifying the browser session
RAPPI_USER_ID — Numeric Rappi user ID
See .env.example for the expected format.
Tools reference
rappi_auth(use_existing_chrome=True)
Extract credentials from Chrome and write them to .env. Set use_existing_chrome=False to launch a fresh Chrome window and wait for login.
rappi_reload()
Reload tokens from .env and restart the API client — without restarting the MCP server. Useful after manually editing .env.
rappi_list_stores(category, query, limit)
List stores available for delivery near your saved address.
| Param | Default | Description |
|---|---|---|
category |
"market" |
Store category: "market", "restaurant", "farma", "licores", "express-big", or any Rappi store_type slug |
query |
"" |
Optional name filter |
limit |
50 |
Max results |
Returns: store_id, name, store_type, lat, lng, eta, shipping_cost.
store_idis used byrappi_search_products.store_typeis used by all cart tools.
rappi_get_store(store_id)
Look up metadata for a specific store by its numeric ID. Returns store_type (the slug needed for cart operations).
rappi_search_products(store_id, query, size, offset)
Search products within a store. Queries in Spanish work best.
| Param | Default | Description |
|---|---|---|
store_id |
required | From rappi_list_stores |
query |
required | Search term (e.g. "cerveza", "preservativos") |
size |
40 |
Results per page (max 40) |
offset |
0 |
Pagination offset |
Returns: composite_id, name, trademark, price, real_price, discount, quantity, unit_type, sale_type, in_stock.
Use
composite_idandsale_typewhen adding to cart.
rappi_get_cart(store_type)
Read the current cart contents for a given store. Returns a list of items with composite_id, units, sale_type, name, price.
rappi_add_to_cart(store_id, store_type, composite_id, units, sale_type)
Add a product to the cart (or increment its quantity if already present). Internally: reads current cart → appends/increments → writes back via a full PUT.
rappi_remove_from_cart(store_id, store_type, composite_id)
Remove a specific product from the cart by its composite_id.
rappi_clear_cart(store_id, store_type)
Empty the entire cart for a store.
rappi_checkout(store_type)
Navigate Chrome to the checkout page for a store. Each store has its own checkout URL:
https://www.rappi.cl/checkout/{store_type}
Examples:
turbo_rappidrinks_nc→rappi.cl/checkout/turbo_rappidrinks_nccruz_verde_rappido_nc→rappi.cl/checkout/cruz_verde_rappido_nclider→rappi.cl/checkout/lider
Rappi does not support consolidated multi-store checkout. Each store cart must be checked out separately.
Typical flow
1. rappi_auth() # authenticate once
2. rappi_list_stores(category="farma") # find pharmacies
3. rappi_search_products(store_id, "preservativos") # search
4. rappi_add_to_cart(store_id, store_type, composite_id, 1, "U")
5. rappi_checkout(store_type) # open checkout in Chrome
File structure
RappiMCP/
├── rappi_mcp.py # MCP server — tool definitions, auth logic, CDP helpers
├── rappi_client.py # Rappi API client with automatic token refresh
├── requirements.txt # Python dependencies
├── .env # Credentials (git-ignored)
└── .env.example # Credentials template
Notes
- The server uses CDP port
9223(not the default9222) to avoid conflicts with other tools - Checkout navigation also uses CDP — the same Chrome instance used for auth
store_typeslugs come fromrappi_list_storesand must be passed exactly as returned (e.g."turbo_rappidrinks_nc", not"turbo")
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file rappi_mcp-0.2.1.tar.gz.
File metadata
- Download URL: rappi_mcp-0.2.1.tar.gz
- Upload date:
- Size: 14.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bd641a7b3aba04fcaa7656c804a714613c9a4593b9fee1957b0aae337554ffba
|
|
| MD5 |
16f70a9a54d3cd41d2c38301658e6d1b
|
|
| BLAKE2b-256 |
3cc78d88ac8fd9b7bb8345e64421f2207a833fe4a498b97df286220bd6e3f1d9
|
File details
Details for the file rappi_mcp-0.2.1-py3-none-any.whl.
File metadata
- Download URL: rappi_mcp-0.2.1-py3-none-any.whl
- Upload date:
- Size: 26.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
682cb7322753dde2e653d303bd0698a9abe37a53e0e414acef917f771c4b1ba6
|
|
| MD5 |
22c1bf4f1be1de12f071ba77b9bbbb0d
|
|
| BLAKE2b-256 |
9201e5865e18eab9cc72727633075ed3f227c7ea2f7e8b1c33b36fe6e6488cdc
|