ssc
OfficialClick on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@sscget offers for B07XYZ123 on Amazon"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
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.
๐ 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 batchreads EANs from stdin, streams NDJSON envelopes.
Related MCP server: Scrapezy
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/sscQuick 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 500Commands
Command | What it does | Credits |
| Show remaining credits + plan info | 0 |
| Recent API calls for this key | 0 |
| All seller offers for an EAN | 1 |
| Product title, brand, images, specs | 1 |
| Current buy-box winner + price | 1 |
| EAN โ marketplace SKU/URL | 1 / 4 |
| Google Shopping search | 1 |
| Structured data from any product URL | 1 |
| Variants for a Google Shopping SKU โ | 6 |
| Reviews + rating distribution | 1 |
| Fan out a command (NDJSON output) | n ร cost |
| List every command (for agent introspection) | 0 |
| 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 200ssc 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:
0ok ยท1user error ยท2auth ยท3rate-limit ยท4upstream ยท5network ยท6spend-cap exceeded.
Pass --pretty for a human-readable view; --quiet to suppress stdout (only the exit code matters).
Authentication
Resolution order:
--api-key <key>flag (avoid โ lands in shell history)SSC_API_KEYenvironment variable (recommended)~/.config/ssc/config.jsonwith{"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 serveRun 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:
Server-side (strongest) โ the ShoppingScraper API enforces
max_credits_per_calland per-key daily caps. Returns HTTP 402 withcredits_required. Cannot be bypassed by anything.Client-side mandatory โ
ssc batchrefuses to run without--max-spend-credits N.Client-side advisory โ global
--max-spend-credits(default 100) on every command; per-tool soft caps; MCPrequiresConfirmationannotations.
To disable client-side caps for a power-user workflow:
ssc batch offers --input eans.txt --site amazon.de --max-spend-credits noneProgrammatic 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 --helpSecurity
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.
๐ Website: shoppingscraper.com
๐ Get an API key: app.shoppingscraper.com
๐ API docs: app.shoppingscraper.com/apiguide
๐จ Contact: hello@shoppingscraper.com
License
MIT โ ยฉ ShoppingScraper
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/ShoppingResult/shoppingscraper-cli'
If you have feedback or need assistance with the MCP directory API, please join our Discord server