Skip to main content

MCP server for Yandex Maps business reviews

Project description

ya-reviews-mcp

License Python FastMCP

Model Context Protocol (MCP) server for Yandex Maps business reviews. Scrapes reviews from any Yandex Maps organization page and exposes them to your AI assistant — review text, ratings, author info, likes/dislikes, business responses, and company metadata.

No API key required. Uses a headless Chromium browser under the hood. Supports multiple browser backends: Playwright, Patchright (anti-detection), or a remote browser via CDP.

Quick Start

1. Install

Choose your backend:

# Option A: Playwright (default)
pip install ya-reviews-mcp[playwright]
playwright install chromium

# Option B: Patchright (better anti-detection)
pip install ya-reviews-mcp[patchright]
patchright install chromium

# Option C: Remote browser (no local browser needed)
pip install ya-reviews-mcp
# Then run a browser separately, e.g.:
# docker run -p 3000:3000 ghcr.io/browserless/chromium

2. Find the Organization ID

Open any business on Yandex Maps and look at the URL:

https://yandex.ru/maps/org/astra_motors/1248139252/reviews/
                                        ^^^^^^^^^^
                                        this is the org_id

3. Configure Your IDE

Add to your Claude Desktop / Cursor MCP configuration:

{
  "mcpServers": {
    "ya-reviews": {
      "command": "uvx",
      "args": ["--from", "ya-reviews-mcp[playwright]", "ya-reviews-mcp"]
    }
  }
}

Using Patchright? Replace ya-reviews-mcp[playwright] with ya-reviews-mcp[patchright] and add "--backend", "patchright" to args.

Running from source? Use uv run instead:

{
  "mcpServers": {
    "ya-reviews": {
      "command": "uv",
      "args": ["run", "--directory", "/path/to/ya-reviews-mcp", "ya-reviews-mcp"]
    }
  }
}

4. Start Using

Ask your AI assistant to:

  • "Get reviews for organization 1248139252" — fetch all reviews with text, ratings, and business responses
  • "Show me company info for org 1248139252" — company name, rating, review count
  • "Give me a summary of org 1248139252 with the last 10 reviews" — company info + recent reviews in one call

Tools

3 tools for Yandex Maps review data:

Tool Description
get_reviews Fetch reviews with text, author, date, rating, likes/dislikes, direct review URL, and business responses. Supports max_reviews limit and sort (by_time or by_rating).
get_company_info Company metadata: name, rating, review count, address, categories.
get_company_summary Company info + recent reviews in one call. Best for a quick business overview.

Review Data Fields

Each review includes:

Field Description
author_name Reviewer's display name
author_icon_url Avatar image URL
author_profile_url Link to the reviewer's Yandex Maps profile
date ISO 8601 date string
text Full review text
stars Rating (1.0 - 5.0)
likes Thumbs up count
dislikes Thumbs down count
review_url Direct link to this specific review
business_response Organization's reply text (if any)

Company Info Fields

Field Description
name Business name
rating Overall rating (e.g., 4.8)
review_count Total number of reviews
address Business address
categories Business categories list

Configuration

All configuration via environment variables (no API key needed):

Variable Default Description
BROWSER_BACKEND playwright Browser backend: playwright, patchright, or remote
BROWSER_WS_URL WebSocket URL for remote backend (e.g., ws://localhost:3000)
BROWSER_HEADLESS true Set to false for visual debugging
PAGE_TIMEOUT 30000 Page load timeout in ms
INTERCEPT_TIMEOUT 15000 Max wait for reviews to appear in DOM (ms)
REQUEST_DELAY 2.0 Delay between scroll loads (seconds)
MAX_PAGES 20 Max scroll iterations (50 reviews per scroll)
SCRAPER_RETRIES 3 Retry attempts for page loads
SCRAPER_RETRY_DELAY 2.0 Base delay between retries (seconds)
BROWSER_LOCALE ru-RU Browser locale
ENABLED_TOOLS all Comma-separated list of allowed tools

Copy .env.example to .env and uncomment the values you want to change.

CLI

# stdio (default, for MCP clients)
ya-reviews-mcp

# HTTP transport
ya-reviews-mcp --transport streamable-http --port 8000

# With verbose logging
ya-reviews-mcp -vv

# Use Patchright backend
ya-reviews-mcp --backend patchright

# Use remote browser
ya-reviews-mcp --backend remote --browser-url ws://localhost:3000

# Load custom .env file
ya-reviews-mcp --env-file /path/to/.env

Installation

From PyPI (with Playwright):

pip install ya-reviews-mcp[playwright]
playwright install chromium

From PyPI (with Patchright):

pip install ya-reviews-mcp[patchright]
patchright install chromium

From PyPI (remote browser only):

pip install ya-reviews-mcp

From source:

git clone https://github.com/mrkhachaturov/ya-reviews-mcp
cd ya-reviews-mcp
uv sync --extra playwright
uv run playwright install chromium
uv run ya-reviews-mcp

How It Works

Unlike ya-metrics-mcp which uses the official Yandex Metrika API, Yandex Maps has no public API for reviews. This server uses a headless browser to:

  1. Navigate to the organization's reviews page on yandex.ru/maps
  2. Parse review data from the server-rendered DOM (schema.org structured data)
  3. Scroll to load additional reviews (50 per scroll, infinite pagination)
  4. Click "Show organization response" buttons to reveal business replies
  5. Extract all fields including likes/dislikes and direct review URLs

A single Chromium browser instance is shared across requests via FastMCP's lifespan context. Each scrape creates a fresh browser context (isolated cookies/state).

Development

# Install with dev dependencies (includes playwright)
uv sync --extra dev

# Install browser
uv run playwright install chromium

# Run tests
uv run pytest

# Lint
uv run ruff check src/

# Type check
uv run mypy src/

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ya_reviews_mcp-0.1.0.tar.gz (124.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ya_reviews_mcp-0.1.0-py3-none-any.whl (24.6 kB view details)

Uploaded Python 3

File details

Details for the file ya_reviews_mcp-0.1.0.tar.gz.

File metadata

  • Download URL: ya_reviews_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 124.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for ya_reviews_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 5182a91c7b9aee4d3d6069769cc7dd2bd76f7f11079d9cf84296865b3119db85
MD5 846693700a488636788e4f2ba4755a32
BLAKE2b-256 995c19601a1014fd1faf5bb9a128591a809d586481e02a5cc1acaab171e437ee

See more details on using hashes here.

File details

Details for the file ya_reviews_mcp-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: ya_reviews_mcp-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 24.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for ya_reviews_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3151647a776300f71581f0e6e8ab4b20ab84e11a9de34ab243d8c93abfa1a92e
MD5 109094cd7882a978842a3da24c962685
BLAKE2b-256 0d1b7e9ef1dd8797eede39cc9d11a1c9f894c1576d1a0f3745206c8ccef9e064

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page