Vinted MCP and CLI Server

Vinted MCP and CLI Server

Complete Vinted MCP and CLI Server

Category
Visit Server

README

<div align="center">

🛍️ Vinted MCP & CLI Server

Give your AI assistant access to Vinted — search, compare prices, and track sellers across 19 countries.

npm version CI License: MIT Node ≥18

</div>


The idea

Vinted has no public API. This package bridges that gap — it lets AI assistants talk directly to Vinted via the Model Context Protocol.

Connect it to Claude, Cursor, or any MCP-compatible assistant and just ask:

"Find me a North Face jacket under €60 in Germany, good condition or better"

"Compare prices for Air Jordan 1s across France, Italy and the UK"

"What is seller #123456 currently selling? Anything under €20?"

The AI figures out which filters to use, calls Vinted, and gives you a real answer — no searching, no filtering, no tabs.

Also ships as a CLI tool and TypeScript library for direct use.


What is this?

An MCP server, CLI tool, and TypeScript library for the Vinted secondhand marketplace. No official API — it bootstraps a session cookie from the public catalog page and calls the private JSON API the Vinted web app uses internally.

  • 🤖 MCP server — plug into Claude, Cursor, or any AI assistant with MCP support
  • 🖥️ CLI tool — pipe results, watch for new listings, compare prices from your terminal
  • 📦 TypeScript library — import opSearch, opCompare, etc. directly in your code

Install

npm install -g @googlarz/vinted-client

Or run without installing:

npx @googlarz/vinted-client search "levis 501"

CLI Quick Start

# Search (JSON by default)
vinted search "levi's 501" --country fr

# Pretty table
vinted search "levi's 501" --country de --output table

# Filter by price, brand, condition
vinted search "adidas samba" \
  --price-min 20 --price-max 80 \
  --brand adidas \
  --condition new_with_tags,very_good \
  --output table

# Watch for new listings every 30s
vinted search "air jordan 1" --watch 30

# Walk all pages and collect up to 500 results
vinted search "vintage denim" --all --max-items 500

# Get a specific item (ID or URL)
vinted item 1234567
vinted item https://www.vinted.fr/items/1234567

# Seller profile + active listings
vinted seller 987654
vinted seller-items 987654 --output table

# Cross-country price comparison (6 countries by default)
vinted compare "north face jacket" --output table

# Browse category tree
vinted categories --query shoes --output table

# Look up brand IDs
vinted brands "stone island"

# What's trending right now
vinted trending --country fr --output table

Commands

Command Description
search <query> Search listings with full filter support
item <id|url> Get full item detail
seller <id> Seller profile
seller-items <id> Items a seller has for sale
compare <query> Price comparison across countries
brands <query> Look up brand IDs by name
categories Browse the category tree
trending Newest / trending listings
debug Inspect session cookies (for troubleshooting)

Global flags

Flag Description
--output json|table Output format (default: json)
--country <cc> Country code (see below)
--proxy <url> HTTP/HTTPS proxy (also: VINTED_PROXY_URL)
--no-cache Disable response cache

Search flags

Flag Description
--price-min / --price-max Price range
--brand <names> Brand names (auto-resolved to IDs)
--brand-ids <ids> Comma-separated brand IDs
--category-id <n> Category ID (vinted categories to browse)
--size-ids <ids> Comma-separated size IDs
--condition <list> new_with_tags, new_without_tags, very_good, good, satisfactory
--sort <s> relevance, price_low_to_high, price_high_to_low, newest_first
--date-from / --date-to Date range filter (YYYY-MM-DD)
--all Walk pages and collect all results
--max-items <n> Cap for --all (default 1000)
--watch [interval] Poll every N seconds for new listings (default 60s)

Supported Countries

fr de uk it es nl pl pt be at lt cz sk hu ro hr fi dk se


MCP Server

Drop Vinted into any MCP-compatible AI assistant (Claude, Cursor, etc.).

Setup — Claude Desktop

Add to claude_desktop_config.json:

{
  "mcpServers": {
    "vinted": {
      "command": "npx",
      "args": ["-y", "@googlarz/vinted-client/mcp"]
    }
  }
}

Setup — Claude Code

claude mcp add vinted -- npx -y @googlarz/vinted-client/mcp

MCP Tools

Tool Description
search_items Search with full filter support
get_item Item detail by ID or URL
get_seller Seller profile
get_seller_items Active listings for a seller
compare_prices Multi-country price comparison
get_trending Trending listings
search_brands Brand lookup
get_categories Category tree

Example prompts once connected:

"Find me Nike Air Max 95s under €70 in Germany, size 43, very good condition"

"Compare prices for a North Face puffer jacket across France, Germany and Italy"

"Watch seller #987654 and tell me when they list something under €30"


Library Usage

import { VintedClient, opSearch, opCompare, opSearchAll } from '@googlarz/vinted-client';

const client = new VintedClient();

// Basic search
const results = await opSearch(client, {
  query: 'levi\'s 501',
  country: 'de',
  priceMax: 50,
  condition: ['very_good', 'good'],
  sortBy: 'price_low_to_high',
});

console.log(results.items);

// Collect all pages concurrently (3-page prefetch window)
const all = await opSearchAll(client, {
  query: 'vintage band tee',
  country: 'uk',
  maxItems: 300,
});

// Multi-country price comparison
const report = await opCompare(client, {
  query: 'air jordan 1 retro',
  countries: ['fr', 'de', 'uk', 'it'],
});

Client options

const client = new VintedClient({
  proxyUrl: 'http://proxy:8080',   // or VINTED_PROXY_URL env var
  cacheTtlMs: 60_000,              // response cache TTL (0 = disable)
  rateLimitPerSec: 3,              // requests/sec per country
  rateLimitBurst: 6,               // burst capacity
  timeoutMs: 20_000,               // per-request timeout
});

How it works

Vinted has no public API. This library:

  1. Bootstraps a session by hitting vinted.{cc}/catalog and capturing the auth cookies the Vinted frontend sets.
  2. Calls the private JSON API (/api/v2/...) with those cookies, mimicking browser request headers.
  3. Re-bootstraps automatically on 401 — tokens expire, the library recovers silently.
  4. Rate-limits per country with a token bucket (configurable burst + refill) to avoid 429s.
  5. Caches responses with LRU+TTL — 60s for search results, 1h for static data like categories.
  6. Falls back to HTML scraping for item pages blocked by DataDome (JSON-LD + regex extraction).
  7. Prefetches 3 pages concurrently in opSearchAll to maximise throughput within the rate-limit budget.

Proxy support

If Vinted blocks your IP (common on cloud VMs and CI), set a proxy:

VINTED_PROXY_URL=http://user:pass@proxy:8080 vinted search "nike"
# or
vinted search "nike" --proxy http://user:pass@proxy:8080

Standard HTTPS_PROXY / HTTP_PROXY env vars are also respected.


Environment variables

Variable Description
VINTED_PROXY_URL HTTP/HTTPS proxy URL
VINTED_CACHE_TTL_MS Cache TTL in ms (default 60000)
VINTED_RATE_LIMIT_PER_SEC Requests per second per country (default 3)
VINTED_RATE_LIMIT_BURST Token bucket burst size (default 6)
VINTED_BROWSER Set to 1 to use stealth browser for item detail

Requirements

  • Node.js ≥ 18
  • Optional: playwright + puppeteer-extra-plugin-stealth for --browser / VINTED_BROWSER=1 mode

License

MIT © googlarz


<div align="center"> <sub>Not affiliated with Vinted UAB. Use responsibly.</sub> </div>

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
Qdrant Server

Qdrant Server

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

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