VIN MCP Server

Free VIN decoder for humans and AI. No API keys. No accounts. No limits.

README.md

VIN MCP

Free VIN decoder for humans and AI. No API keys. No accounts. No limits.

mcp.vin -- Try it now


What It Does

Enter a 17-character VIN and get a comprehensive vehicle report by aggregating six free data sources into a single response:

Source Data Provided
NHTSA vPIC Make, model, year, trim, body class, engine specs, transmission, drive type, weight, plant info, 140+ decoded fields
NHTSA Recalls Open recalls with campaign number, component, summary, consequence, and remedy
NHTSA Complaints Consumer complaints with crash, fire, injury, and death statistics
NHTSA Safety Ratings NCAP star ratings for overall, frontal, side, and rollover crash tests
EPA Fuel Economy City/highway/combined MPG, annual fuel cost, CO2 emissions, EV range and charge time
IMAGIN.studio Stock vehicle photos from multiple angles

Additionally, VIN validation (checksum, WMI country/manufacturer decode, model year) is computed locally with zero API calls.


Quick Start -- Connect via MCP

Smithery (one command)

npx -y @smithery/cli install @keptlive/vin-mcp --client claude

Claude Code (stdio)

Add to your .mcp.json:

{
  "mcpServers": {
    "vin": {
      "command": "npx",
      "args": ["-y", "vin-mcp"]
    }
  }
}

Or if you have the repo cloned locally:

{
  "mcpServers": {
    "vin": {
      "command": "node",
      "args": ["/path/to/vin-mcp/server.mjs"]
    }
  }
}

Claude Desktop / claude.ai (HTTP)

Use the hosted MCP endpoint:

https://mcp.vin/mcp

Add to your Claude Desktop config:

{
  "mcpServers": {
    "vin": {
      "url": "https://mcp.vin/mcp"
    }
  }
}

MCP Tools

Tool Description Input
decode_vin Full VIN decode with specs, recalls, complaints, safety ratings, fuel economy, and photos { vin: string }
validate_vin Quick local validation -- checksum, WMI country/manufacturer, model year. No external API calls { vin: string }
lookup_recalls Look up recalls by VIN or by make/model/year { vin?: string, make?: string, model?: string, year?: number }
batch_decode Decode up to 50 VINs in a single request via NHTSA batch API { vins: string[] }

REST API

All endpoints are available at https://mcp.vin or on your self-hosted instance.

Method Endpoint Description
GET /api/vin/:vin Full decode -- all 6 sources aggregated
GET /api/vin/:vin/validate Quick checksum and format validation
GET /api/vin/:vin/recalls Recall data only
GET /api/vin/:vin/complaints Consumer complaints only
GET /api/vin/:vin/safety NCAP safety ratings only
GET /api/vin/:vin/fuel EPA fuel economy only
GET /api/vin/:vin/photo Redirects to vehicle photo URL
POST /api/batch Batch decode (body: { "vins": ["VIN1", "VIN2", ...] }, max 50)

Rate limits: 30 requests/minute per IP for most endpoints, 60/minute for validation and photos, 5/minute for batch.

Example:

curl https://mcp.vin/api/vin/1HGCM82633A004352

Direct VIN URLs also work -- visit https://mcp.vin/1HGCM82633A004352 to see the web report.


Self-Hosting

git clone https://github.com/keptlive/vin-mcp.git
cd vin-mcp
npm install
node server.mjs --http --port 3200

The server starts in HTTP mode with:

  • Web frontend at http://localhost:3200
  • REST API at http://localhost:3200/api/vin/{vin}
  • MCP endpoint at http://localhost:3200/mcp

For stdio mode (Claude Code integration without a web server):

node server.mjs

How VINs Work

A VIN (Vehicle Identification Number) is a 17-character code assigned to every vehicle manufactured since 1981. Each position encodes specific information:

1 H G C M 8 2 6 3 3 A 0 0 4 3 5 2
|_____| |___| | | | |_| |_________|
  WMI    VDS  | | | |yr  Sequential
              | | | plant
              | | check digit
              | vehicle attributes
              manufacturer ID
  • Positions 1-3 (WMI): World Manufacturer Identifier -- country and manufacturer
  • Positions 4-8 (VDS): Vehicle Descriptor Section -- model, body, engine, transmission
  • Position 9: Check digit -- validates the VIN using a weighted algorithm
  • Position 10: Model year code (A-Y, 1-9 on a 30-year cycle)
  • Position 11: Assembly plant
  • Positions 12-17: Sequential production number

The l

Tools 4

decode_vinFull VIN decode with specs, recalls, complaints, safety ratings, fuel economy, and photos
validate_vinQuick local validation -- checksum, WMI country/manufacturer, model year. No external API calls
lookup_recallsLook up recalls by VIN or by make/model/year
batch_decodeDecode up to 50 VINs in a single request via NHTSA batch API

Try it

Decode the VIN 1HGCM82633A004352 and give me a summary of its safety ratings and fuel economy.
Check if there are any open recalls for a 2020 Honda Civic.
Validate this VIN: 1HGCM82633A004352 to see if it is a legitimate vehicle identification number.
Batch decode these VINs: [VIN1, VIN2] and compare their fuel efficiency.

Frequently Asked Questions

What are the key features of VIN MCP?

Aggregates data from NHTSA vPIC, Recalls, Complaints, and Safety Ratings. Provides EPA fuel economy data including MPG and CO2 emissions. Retrieves stock vehicle photos from IMAGIN.studio. Performs local VIN validation without external API calls. Supports batch decoding for up to 50 VINs.

What can I use VIN MCP for?

Quickly verifying vehicle specifications before a used car purchase. Checking for outstanding safety recalls on a specific vehicle. Comparing fuel economy and environmental impact across multiple vehicle models. Automating vehicle data collection for automotive research or inventory management.

How do I install VIN MCP?

Install VIN MCP by running: npx -y @smithery/cli install @keptlive/vin-mcp --client claude

What MCP clients work with VIN MCP?

VIN MCP works with any MCP-compatible client including Claude Desktop, Claude Code, Cursor, and other editors with MCP support.

Turn this server into reusable context

Keep VIN MCP docs, env vars, and workflow notes in Conare so your agent carries them across sessions.

Open Conare