ssc

ssc

MCP server for scraping product prices, offers, reviews, and details from Amazon, Google Shopping, Bol.com, and Coolblue via natural language commands, with spend-cap protections.

Category
Visit Server

README

ssc โ€” ShoppingScraper CLI

Price scraper CLI for Amazon, Google Shopping, Bol.com, and Coolblue. Scrape prices, offers, buy-box winners, variants, and reviews from your terminal โ€” or wire it into Claude Desktop / Cursor / Claude Code as a native MCP tool.

npm version CI License: MIT

๐ŸŒ Website: shoppingscraper.com ยท ๐Ÿ”‘ Get an API key: app.shoppingscraper.com ยท ๐Ÿ“– API docs: apiguide

Agent-friendly command-line tool for the ShoppingScraper API by shoppingscraper.com. Stable JSON envelope on every command, MCP server mode for Claude Desktop / Cursor / Code, ships with a SKILL.md so any LLM picks it up without schema wrapping.

Why

You're an AI agent (or a developer building one) and you need product data โ€” prices, offers, buy-box winners, variants, reviews โ€” from Google Shopping, Amazon, Bol.com, or Coolblue. Today you're hitting the raw HTTP API and writing the same retry/error/credit-tracking glue every time. ssc is that glue, in one binary, with a stable contract.

Use cases:

  • Price monitoring CLI โ€” fan out across thousands of EANs from cron / GitHub Actions / your CI.
  • E-commerce scraping โ€” match an EAN to a marketplace SKU, pull every offer, watch the buy-box.
  • AI agents โ€” give Claude/Cursor live marketplace data via the built-in MCP server.
  • Bulk price scraping โ€” ssc batch reads EANs from stdin, streams NDJSON envelopes.

Install

# Run without installing
npx -y @shoppingscraper/cli credits

# Global install
npm install -g @shoppingscraper/cli

# Or via Homebrew (post-launch)
brew install ShoppingResult/tap/ssc

Quick start

# 1. Set your API key (get one at https://app.shoppingscraper.com)
export SSC_API_KEY="<your-key>"

# 2. Verify
ssc credits
# โ†’ {"_v":1,"ok":true,"command":"credits","result":{...},"meta":{...}}

# 3. Get offers for an EAN on a marketplace
ssc offers --site amazon.de --ean 0190198001281

# 4. Pretty output for humans
ssc buybox --site bol.com --ean 0190198001281 --pretty

# 5. Pipe-friendly: get just the result payload
ssc info --site shopping.google.nl --ean 0190198001281 | jq '.result'

# 6. Bulk: 500 EANs from a file, capped at 500 credits
ssc batch offers --input eans.txt --site amazon.de --max-spend-credits 500

Commands

Command What it does Credits
ssc credits Show remaining credits + plan info 0
ssc history Recent API calls for this key 0
ssc offers --site --ean All seller offers for an EAN 1
ssc info --site --ean Product title, brand, images, specs 1
ssc buybox --site --ean Current buy-box winner + price 1
ssc match --site --ean [--deepsearch] EAN โ†’ marketplace SKU/URL 1 / 4
ssc search --country --keyword Google Shopping search 1
ssc page --url Structured data from any product URL 1
ssc variants --site --sku Variants for a Google Shopping SKU โš  6
ssc reviews --site --sku Reviews + rating distribution 1
ssc batch <cmd> --input Fan out a command (NDJSON output) n ร— cost
ssc tools [--json-schema] List every command (for agent introspection) 0
ssc mcp serve MCP server over stdio 0

โš  = high-cost, gets requiresConfirmation: true in MCP tool annotations.

Bulk / streaming

Every scraping command accepts --input <file|->. Reads one EAN/SKU per line, fans out with the configured concurrency (default 5), jitters each request 200โ€“800ms, streams NDJSON envelopes. Lines beginning with # are comments.

# From a file
ssc offers --input eans.txt --site amazon.de --max-spend-credits 500

# From stdin
cat eans.txt | ssc info --site bol.com --input - --max-spend-credits 100

# `ssc batch` is sugar with a mandatory cap
ssc batch buybox --input eans.txt --site amazon.de --max-spend-credits 200

ssc batch requires --max-spend-credits N โ€” there is no default. This is deliberate: agents bypassing this flag is the highest-blast-radius mistake an MCP-driven workflow can make.

Output format

Every command emits a stable JSON envelope on stdout (one line for batch/streaming):

{
  "_v": 1,
  "ok": true,
  "command": "offers",
  "result": { /* endpoint payload */ },
  "error": null,
  "meta": {
    "credits_remaining": 12483,
    "duration_ms": 412,
    "request_id": "ssc_01a2b3c4d5e6f708"
  }
}

On failure: ok: false, result: null, error.code is one of AUTH_MISSING | AUTH_INVALID | RATE_LIMITED | UPSTREAM_ERROR | NETWORK_ERROR | SPEND_CAP_EXCEEDED | NOT_FOUND | INVALID_RESPONSE | USER_ERROR.

Exit codes:

  • 0 ok ยท 1 user error ยท 2 auth ยท 3 rate-limit ยท 4 upstream ยท 5 network ยท 6 spend-cap exceeded.

Pass --pretty for a human-readable view; --quiet to suppress stdout (only the exit code matters).

Authentication

Resolution order:

  1. --api-key <key> flag (avoid โ€” lands in shell history)
  2. SSC_API_KEY environment variable (recommended)
  3. ~/.config/ssc/config.json with {"api_key": "..."} (mode 0600 recommended)

The CLI sends the key as a query-string parameter (?api_key=...) to match the deployed ShoppingScraper API contract. All URLs are redacted before they appear in logs, error envelopes, or meta.request_id.

MCP โ€” Model Context Protocol

ssc mcp serve

Run as a stdio MCP server, exposing every command as a tool (ssc_offers, ssc_info, ssc_buybox, โ€ฆ). Tool input schemas are auto-derived from the same zod schemas the CLI uses, so agents and humans see the same contract.

Claude Desktop

Add to ~/Library/Application Support/Claude/claude_desktop_config.json:

{
  "mcpServers": {
    "shoppingscraper": {
      "command": "npx",
      "args": ["-y", "@shoppingscraper/cli", "mcp", "serve"],
      "env": { "SSC_API_KEY": "<your-key>" }
    }
  }
}

Cursor / Claude Code

Same shape โ€” point any MCP-compatible host at npx -y @shoppingscraper/cli mcp serve with SSC_API_KEY in the env.

Tool annotations

High-cost tools (ssc_variants, ssc_match with --deepsearch, anything bulk) carry requiresConfirmation: true. This annotation is advisory โ€” well-behaved hosts prompt before invoking; hostile or headless clients ignore it. The real spend-cap brake is --max-spend-credits and the server-side cap on your ShoppingScraper API plan.

Spend-cap defenses

Three layers, in order of strength:

  1. Server-side (strongest) โ€” the ShoppingScraper API enforces max_credits_per_call and per-key daily caps. Returns HTTP 402 with credits_required. Cannot be bypassed by anything.
  2. Client-side mandatory โ€” ssc batch refuses to run without --max-spend-credits N.
  3. Client-side advisory โ€” global --max-spend-credits (default 100) on every command; per-tool soft caps; MCP requiresConfirmation annotations.

To disable client-side caps for a power-user workflow:

ssc batch offers --input eans.txt --site amazon.de --max-spend-credits none

Programmatic use

import { HttpClient, endpoints, resolveConfig } from "@shoppingscraper/cli";

const cfg = resolveConfig();
const client = new HttpClient({
  apiKey: cfg.apiKey,
  baseUrl: cfg.baseUrl,
  appBaseUrl: cfg.appBaseUrl,
  timeoutMs: 30_000,
  retries: 2,
});
const r = await endpoints.offers(client, { site: "amazon.de", ean: "0190198001281" });
console.log(r.creditsRemaining, r.data);
await client.close();

Development

npm install
npm run typecheck
npm test
npm run build
node dist/cli.js --help

Security

See SECURITY.md. Found a vulnerability? Email security@shoppingscraper.com. Please do not open a public issue.

About ShoppingScraper

ssc is built and maintained by ShoppingScraper โ€” the e-commerce price-scraping API for Amazon, Google Shopping, Bol.com, Coolblue, and 30+ other marketplaces. EAN-precise, real-time, and built for AI agents.

License

MIT โ€” ยฉ ShoppingScraper

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