Market Data
GET /v1/prices/snapshot.ndjson.gz — Full Price Snapshot
Download the full CSBoard price catalog as a gzipped NDJSON file. One PriceRow per line. Designed for bulk ingestion with ETag-based conditional fetching.
GET
Full price-list snapshot (gzipped NDJSON)
The snapshot endpoint serves the complete CSBoard price list as a single gzipped NDJSON file. Every decompressed line is one
Example decompressed output:
A
PriceRow JSON object — the same schema returned by GET /v1/prices. This is the intended path for full-catalog consumers such as comparison sites, arbitrage bots, or data pipelines that need a complete local copy of the price list. For targeted queries against a subset of items, use GET /v1/prices instead.
Authentication required. Send your key as Authorization: Bearer csb_pub_....
Rate limit: 1 request per minute, separate from the general 30 requests/min limit. Plan your polling interval accordingly.
Request headers
Pass the
ETag value from a previous snapshot response to make a conditional request. If the snapshot has not changed since that ETag, the server returns 304 Not Modified with no body, saving bandwidth and avoiding a fresh download.Response headers
| Header | Description |
|---|---|
ETag | Opaque version string identifying this snapshot. Store it and send back as If-None-Match on the next request. |
Content-Encoding | gzip — the body is always gzip-compressed. |
Response body
A gzip-compressed stream. After decompression, each newline-delimited line is a valid JSON object conforming to thePriceRow schema:
| Field | Type | Description |
|---|---|---|
market_hash_name | string | Steam market hash name. |
wear | string | null | Wear bucket, or null. |
doppler_phase | string | null | Doppler phase, or null. |
min_price_usd | number | Cheapest current ask in USD. |
qty | integer | Number of listings in this group. |
Example: download and inspect
Example: conditional request with ETag
On the first download you receive anETag header. Pass it back on subsequent requests to avoid re-downloading an unchanged snapshot:
304 Not Modified response means the snapshot is identical to the one you already have — no new download needed.
Error codes
| HTTP status | Code | Meaning |
|---|---|---|
| 304 | (no body) | Snapshot unchanged since the supplied If-None-Match ETag. |
| 401 | unauthorized | Missing or invalid API key. |
| 429 | snapshot_rate_limited | Over the 1 request/min snapshot-specific rate limit. Wait before retrying. |
This endpoint is designed for full-catalog ingestion. If you only need prices for a specific item or a filtered subset, use
GET /v1/prices — it supports search, category, and wear filters and does not count against the snapshot rate limit.Authorizations
Send your key as a Bearer token on every request: Authorization: Bearer csb_pub_.... Generate keys in your CSBoard profile.
Headers
Conditional request. Pass the ETag from a previous snapshot to receive 304 if unchanged.
Response
Gzipped NDJSON stream. Each decompressed line is one PriceRow JSON object. Sets an ETag header.
The response is of type file.
GET /v1/prices — CS2 minAsk Price List by Item Group
Previous
GET /v1/currency — FX Rates for USD Price Conversion
Next