# NHTSA Vehicle Catalog Scraper (VPIC) (`crawlerbros/autotrader-us-vehicle-catalog`) Actor

Scrape US vehicle data from the NHTSA VPIC and Product Information Catalog - search makes, models, recalls, safety ratings, and complaints for all vehicle years. Free public API, no proxy, no auth required.

- **URL**: https://apify.com/crawlerbros/autotrader-us-vehicle-catalog.md
- **Developed by:** [Crawler Bros](https://apify.com/crawlerbros) (community)
- **Categories:** Automation, Developer tools, Integrations
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, NaN bookmarks
- **User rating**: No ratings yet

## Pricing

from $3.00 / 1,000 results

This Actor is paid per event and usage. You are charged both the fixed price for specific events and for Apify platform usage.
Since this Actor supports Apify Store discounts, the price gets lower the higher subscription plan you have.

Learn more: https://docs.apify.com/platform/actors/running/actors-in-store#pay-per-event

## What's an Apify Actor?

Actors are a software tools running on the Apify platform, for all kinds of web data extraction and automation use cases.
In Batch mode, an Actor accepts a well-defined JSON input, performs an action which can take anything from a few seconds to a few hours,
and optionally produces a well-defined JSON output, datasets with results, or files in key-value store.
In Standby mode, an Actor provides a web server which can be used as a website, API, or an MCP server.
Actors are written with capital "A".

## How to integrate an Actor?

If asked about integration, you help developers integrate Actors into their projects.
You adapt to their stack and deliver integrations that are safe, well-documented, and production-ready.
The best way to integrate Actors is as follows.

In JavaScript/TypeScript projects, use official [JavaScript/TypeScript client](https://docs.apify.com/api/client/js.md):

```bash
npm install apify-client
```

In Python projects, use official [Python client library](https://docs.apify.com/api/client/python.md):

```bash
pip install apify-client
```

In shell scripts, use [Apify CLI](https://docs.apify.com/cli/docs.md):

````bash
# MacOS / Linux
curl -fsSL https://apify.com/install-cli.sh | bash
# Windows
irm https://apify.com/install-cli.ps1 | iex
```bash

In AI frameworks, you might use the [Apify MCP server](https://docs.apify.com/platform/integrations/mcp.md).

If your project is in a different language, use the [REST API](https://docs.apify.com/api/v2.md).

For usage examples, see the [API](#api) section below.

For more details, see Apify documentation as [Markdown index](https://docs.apify.com/llms.txt) and [Markdown full-text](https://docs.apify.com/llms-full.txt).


# README

## AutoTrader US — NHTSA Vehicle Catalog Scraper

Scrape US vehicle data from the **NHTSA (National Highway Traffic Safety Administration)** free public APIs. Get vehicle makes, models, safety recalls, NCAP crash test ratings, and full VIN decodes for any US-market vehicle. No authentication, no proxy, no API key required.

> **Data source:** [NHTSA VPIC API](https://vpic.nhtsa.dot.gov/api/) + [NHTSA Safety API](https://api.nhtsa.gov/) — the official US federal vehicle database, updated continuously.

### What this actor does

- **Search vehicles by make and year** — list all model variants for a given manufacturer and model year, filtered by vehicle type (car, truck, motorcycle, etc.)
- **Get all models for a make** — full historical catalog of every model ever produced by a manufacturer
- **Get safety recalls** — official NHTSA recall campaigns with component details, risk descriptions, and remedies
- **Get NCAP safety ratings** — government crash test star ratings (overall, front crash, side crash, rollover)
- **Decode a VIN** — extract full vehicle specs from a 17-character VIN (make, model, year, engine, trim, plant, etc.)

### Input fields

| Field | Type | Description |
|-------|------|-------------|
| `mode` | Select | `searchByMakeYear` (default), `getModels`, `getRecalls`, `getSafetyRatings`, `decodeVin` |
| `make` | String | Vehicle manufacturer (e.g. `Toyota`, `Ford`, `Honda`) |
| `model` | String | Vehicle model (e.g. `Camry`, `F-150`) — required for recall and rating modes |
| `modelYear` | Integer | 4-digit model year (default: 2020) |
| `vehicleType` | Select | `car`, `truck`, `motorcycle`, `bus`, `trailer`, `mpv` |
| `vin` | String | 17-character VIN for `decodeVin` mode |
| `maxItems` | Integer | Maximum records to return (1–1000, default: 50) |

### Output fields

Each record includes `sourceUrl`, `scrapedAt`, and `recordType`. Additional fields by mode:

**Vehicle model records:**
- `make`, `makeId`, `model`, `modelId`, `modelYear`, `vehicleType`, `vehicleTypeId`

**Recall records:**
- `campaignNumber`, `manufacturer`, `make`, `model`, `modelYear`, `subject`, `component`, `consequence`, `remedy`, `reportReceivedDate`, `parkIt`, `parkOutside`, `overTheAirUpdate`

**Safety rating records:**
- `vehicleId`, `vehicleDescription`, `overallRating`, `overallFrontCrashRating`, `frontCrashDriversideRating`, `frontCrashPassengersideRating`, `overallSideCrashRating`, `sideCrashDriversideRating`, `rolloverRating`, `rolloverPossibility`

**VIN decode records:**
- `vin`, `make`, `model`, `modelYear`, `bodyClass`, `cylinders`, `engineDisplacementL`, `fuelTypePrimary`, `driveType`, `transmissionStyle`, `vehicleType`, `trim`, `series`, `doors`, `plantCountry`, `manufacturer`

### Example use cases

- **Automotive research** — get all vehicle models from a specific brand for a model year
- **Safety compliance** — pull all active recalls for a fleet of vehicles by make/model/year
- **Pre-purchase checks** — decode a VIN to verify vehicle specs before buying
- **Data enrichment** — add crash test ratings to vehicle listings

### FAQs

**Is this free to use?**
Yes. The NHTSA APIs are free public federal government APIs with no rate limits or authentication required.

**How fresh is the data?**
NHTSA updates recall and safety data continuously. Vehicle catalog data reflects the VPIC database, updated regularly.

**What makes are available?**
All vehicles sold in the US market — Toyota, Ford, Honda, Chevrolet, BMW, Mercedes-Benz, Tesla, and thousands more including commercial vehicles, motorcycles, and trailers.

**Can I get recalls for all makes at once?**
Use `mode=getRecalls` with a specific make/model/year. For bulk recall data across many models, run multiple searches.

**What VIN formats are supported?**
Standard 17-character North American VINs. Pre-1981 vehicles (shorter VINs) may return partial data.

# Actor input Schema

## `mode` (type: `string`):

What to fetch.
## `make` (type: `string`):

Vehicle manufacturer (e.g. Toyota, Ford, Honda). Required for most modes.
## `model` (type: `string`):

Vehicle model name (e.g. Camry, F-150). Required for recall/rating modes.
## `modelYear` (type: `integer`):

Vehicle model year (e.g. 2020). Required for most modes.
## `vehicleType` (type: `string`):

Filter results by vehicle body type.
## `vin` (type: `string`):

17-character Vehicle Identification Number to decode.
## `maxItems` (type: `integer`):

Hard cap on emitted records.

## Actor input object example

```json
{
  "mode": "searchByMakeYear",
  "make": "Toyota",
  "model": "Camry",
  "modelYear": 2020,
  "vehicleType": "car",
  "maxItems": 50
}
````

# Actor output Schema

## `vehicles` (type: `string`):

Dataset containing all scraped vehicle records.

# API

You can run this Actor programmatically using our API. Below are code examples in JavaScript, Python, and CLI, as well as the OpenAPI specification and MCP server setup.

## JavaScript example

```javascript
import { ApifyClient } from 'apify-client';

// Initialize the ApifyClient with your Apify API token
// Replace the '<YOUR_API_TOKEN>' with your token
const client = new ApifyClient({
    token: '<YOUR_API_TOKEN>',
});

// Prepare Actor input
const input = {
    "mode": "searchByMakeYear",
    "make": "Toyota",
    "model": "Camry",
    "modelYear": 2020,
    "vehicleType": "car",
    "maxItems": 50
};

// Run the Actor and wait for it to finish
const run = await client.actor("crawlerbros/autotrader-us-vehicle-catalog").call(input);

// Fetch and print Actor results from the run's dataset (if any)
console.log('Results from dataset');
console.log(`💾 Check your data here: https://console.apify.com/storage/datasets/${run.defaultDatasetId}`);
const { items } = await client.dataset(run.defaultDatasetId).listItems();
items.forEach((item) => {
    console.dir(item);
});

// 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/js/docs

```

## Python example

```python
from apify_client import ApifyClient

# Initialize the ApifyClient with your Apify API token
# Replace '<YOUR_API_TOKEN>' with your token.
client = ApifyClient("<YOUR_API_TOKEN>")

# Prepare the Actor input
run_input = {
    "mode": "searchByMakeYear",
    "make": "Toyota",
    "model": "Camry",
    "modelYear": 2020,
    "vehicleType": "car",
    "maxItems": 50,
}

# Run the Actor and wait for it to finish
run = client.actor("crawlerbros/autotrader-us-vehicle-catalog").call(run_input=run_input)

# Fetch and print Actor results from the run's dataset (if there are any)
print("💾 Check your data here: https://console.apify.com/storage/datasets/" + run["defaultDatasetId"])
for item in client.dataset(run["defaultDatasetId"]).iterate_items():
    print(item)

# 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/python/docs/quick-start

```

## CLI example

```bash
echo '{
  "mode": "searchByMakeYear",
  "make": "Toyota",
  "model": "Camry",
  "modelYear": 2020,
  "vehicleType": "car",
  "maxItems": 50
}' |
apify call crawlerbros/autotrader-us-vehicle-catalog --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=crawlerbros/autotrader-us-vehicle-catalog",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "NHTSA Vehicle Catalog Scraper (VPIC)",
        "description": "Scrape US vehicle data from the NHTSA VPIC and Product Information Catalog - search makes, models, recalls, safety ratings, and complaints for all vehicle years. Free public API, no proxy, no auth required.",
        "version": "1.0",
        "x-build-id": "wETWElRBsMn6vGr7W"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/crawlerbros~autotrader-us-vehicle-catalog/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-crawlerbros-autotrader-us-vehicle-catalog",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for its completion, and returns Actor's dataset items in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        },
        "/acts/crawlerbros~autotrader-us-vehicle-catalog/runs": {
            "post": {
                "operationId": "runs-sync-crawlerbros-autotrader-us-vehicle-catalog",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor and returns information about the initiated run in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK",
                        "content": {
                            "application/json": {
                                "schema": {
                                    "$ref": "#/components/schemas/runsResponseSchema"
                                }
                            }
                        }
                    }
                }
            }
        },
        "/acts/crawlerbros~autotrader-us-vehicle-catalog/run-sync": {
            "post": {
                "operationId": "run-sync-crawlerbros-autotrader-us-vehicle-catalog",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        }
    },
    "components": {
        "schemas": {
            "inputSchema": {
                "type": "object",
                "required": [
                    "mode"
                ],
                "properties": {
                    "mode": {
                        "title": "Mode",
                        "enum": [
                            "searchByMakeYear",
                            "getModels",
                            "getRecalls",
                            "getSafetyRatings",
                            "decodeVin"
                        ],
                        "type": "string",
                        "description": "What to fetch.",
                        "default": "searchByMakeYear"
                    },
                    "make": {
                        "title": "Vehicle make",
                        "type": "string",
                        "description": "Vehicle manufacturer (e.g. Toyota, Ford, Honda). Required for most modes.",
                        "default": "Toyota"
                    },
                    "model": {
                        "title": "Vehicle model",
                        "type": "string",
                        "description": "Vehicle model name (e.g. Camry, F-150). Required for recall/rating modes.",
                        "default": "Camry"
                    },
                    "modelYear": {
                        "title": "Model year",
                        "minimum": 1900,
                        "maximum": 2030,
                        "type": "integer",
                        "description": "Vehicle model year (e.g. 2020). Required for most modes.",
                        "default": 2020
                    },
                    "vehicleType": {
                        "title": "Vehicle type filter",
                        "enum": [
                            "",
                            "car",
                            "truck",
                            "motorcycle",
                            "bus",
                            "trailer",
                            "multipurpose passenger vehicle (mpv)"
                        ],
                        "type": "string",
                        "description": "Filter results by vehicle body type.",
                        "default": "car"
                    },
                    "vin": {
                        "title": "VIN (mode=decodeVin)",
                        "type": "string",
                        "description": "17-character Vehicle Identification Number to decode."
                    },
                    "maxItems": {
                        "title": "Max items",
                        "minimum": 1,
                        "maximum": 1000,
                        "type": "integer",
                        "description": "Hard cap on emitted records.",
                        "default": 50
                    }
                }
            },
            "runsResponseSchema": {
                "type": "object",
                "properties": {
                    "data": {
                        "type": "object",
                        "properties": {
                            "id": {
                                "type": "string"
                            },
                            "actId": {
                                "type": "string"
                            },
                            "userId": {
                                "type": "string"
                            },
                            "startedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "finishedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "status": {
                                "type": "string",
                                "example": "READY"
                            },
                            "meta": {
                                "type": "object",
                                "properties": {
                                    "origin": {
                                        "type": "string",
                                        "example": "API"
                                    },
                                    "userAgent": {
                                        "type": "string"
                                    }
                                }
                            },
                            "stats": {
                                "type": "object",
                                "properties": {
                                    "inputBodyLen": {
                                        "type": "integer",
                                        "example": 2000
                                    },
                                    "rebootCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "restartCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "resurrectCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "computeUnits": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "options": {
                                "type": "object",
                                "properties": {
                                    "build": {
                                        "type": "string",
                                        "example": "latest"
                                    },
                                    "timeoutSecs": {
                                        "type": "integer",
                                        "example": 300
                                    },
                                    "memoryMbytes": {
                                        "type": "integer",
                                        "example": 1024
                                    },
                                    "diskMbytes": {
                                        "type": "integer",
                                        "example": 2048
                                    }
                                }
                            },
                            "buildId": {
                                "type": "string"
                            },
                            "defaultKeyValueStoreId": {
                                "type": "string"
                            },
                            "defaultDatasetId": {
                                "type": "string"
                            },
                            "defaultRequestQueueId": {
                                "type": "string"
                            },
                            "buildNumber": {
                                "type": "string",
                                "example": "1.0.0"
                            },
                            "containerUrl": {
                                "type": "string"
                            },
                            "usage": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "integer",
                                        "example": 1
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "usageTotalUsd": {
                                "type": "number",
                                "example": 0.00005
                            },
                            "usageUsd": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "number",
                                        "example": 0.00005
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
