ebay-mcp

ebay-mcp

Enables Claude to search eBay listings, analyze price distributions, find deals, and generate market research overviews via the Model Context Protocol.

Category
Visit Server

README

ebay-mcp

Expose eBay's marketplace to Claude over the Model Context Protocol. Claude can search active listings, analyse price distributions, surface deals priced below the market median, and produce a market-research overview — all as structured JSON it can reason about.

It answers questions like:

  • What does a used Nintendo Switch OLED actually sell for right now?
  • Find me listings priced well below the going rate.
  • Give me a market overview: price spread, condition mix, who's selling, and shipping.

How it works

                       OAuth2 (client credentials)
                              │
 ┌────────┐   tools    ┌──────┴───────┐   HTTPS   ┌──────────────────┐
 │ Claude │ ────────►  │  ebay-mcp    │ ────────► │ eBay Buy Browse  │
 │        │ ◄────────  │  MCP server  │ ◄──────── │ API              │
 └────────┘    JSON    └──────────────┘           └──────────────────┘

The server authenticates to eBay with the OAuth2 client-credentials grant (caching and refreshing the application token), calls the Buy Browse API, normalises the verbose responses into typed objects, and runs price/market analysis locally before handing JSON back to Claude.

The code is layered so the analysis is testable without the network:

  • config.py — environment-driven configuration.
  • models.py — typed value objects parsed from eBay JSON.
  • auth.py — OAuth token caching/refresh (concurrency-safe).
  • client.py — the only module that talks to eBay; retries + filter grammar.
  • analysis.py — pure price/deal/market functions.
  • server.py — the MCP tools.

Tools

Tool What it does
search_products Search active listings (sort, condition, price range, free-shipping filters).
analyze_prices Price distribution for a query: min/max, mean, median, p25/p75/p90, stdev.
find_deals Listings priced at least N% below the market median, ranked by discount.
market_research Full overview: price stats, condition mix, price-by-condition, shipping, seller locations, observations.
get_item_details Full details for a single listing by item id.

All prices are isolated to a single currency and, unless noted, reflect total cost (item + shipping).

Setup

Requires Python 3.10+ and an eBay developer account.

  1. Create an application at https://developer.ebay.com/my/keys and copy the App ID (Client ID) and Cert ID (Client Secret).

  2. Install:

    git clone https://github.com/luke-nielsen/ebay-mcp.git
    cd ebay-mcp
    python3 -m venv .venv && source .venv/bin/activate
    pip install -e ".[dev]"
    
  3. Configure credentials (copy .env.example to .env, or export directly):

    export EBAY_CLIENT_ID=your-app-id
    export EBAY_CLIENT_SECRET=your-cert-id
    
  4. Verify connectivity:

    ebay-mcp check
    ebay-mcp search "nintendo switch oled" --limit 5
    ebay-mcp research "airpods pro 2"
    

Connecting to Claude

Add the server to your MCP host. For Claude Code:

claude mcp add ebay -- ebay-mcp serve

Or use the bundled .mcp.json (it reads EBAY_CLIENT_ID / EBAY_CLIENT_SECRET from your environment). The server speaks MCP over stdio.

Configuration

Variable Default Description
EBAY_CLIENT_ID App ID (Client ID). Required.
EBAY_CLIENT_SECRET Cert ID (Client Secret). Required.
EBAY_ENVIRONMENT production production or sandbox.
EBAY_MARKETPLACE_ID EBAY_US e.g. EBAY_GB, EBAY_DE, EBAY_AU.
EBAY_DELIVERY_COUNTRY Buyer country for shipping estimates.
EBAY_DELIVERY_POSTAL_CODE Buyer postal code for shipping estimates.
EBAY_TIMEOUT 20 Per-request timeout (seconds).
EBAY_MAX_RETRIES 3 Retry attempts for transient failures.

Development

pip install -e ".[dev]"
pytest        # run the test suite
ruff check .  # lint

The networking layer is exercised with httpx.MockTransport, so the full suite runs offline and needs no credentials.

Notes & limitations

  • Uses the Buy Browse API, which covers active listings. Sold/completed price history requires eBay's restricted Marketplace Insights API and is out of scope here; "market" statistics are therefore over current asking prices.
  • The client-credentials token grants access to public search only — no user-specific or order data.
  • eBay rate limits the Browse API (default ~5,000 calls/day); the analysis tools spend one call each.

License

MIT — see LICENSE.

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured