Skip to main content
Glama

VIN MCP

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

License: MIT Node.js 18+ MCP Compatible

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

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 letters I, O, and Q are never used in VINs to avoid confusion with 1, 0, and 9.


Tech Stack

  • Runtime: Node.js 18+

  • Server: Express 5

  • MCP SDK: @modelcontextprotocol/sdk with stdio and Streamable HTTP transports

  • Frontend: Vanilla HTML, CSS, and JavaScript

  • Caching: In-memory LRU with TTL (1h for decodes, 6h for recalls, 24h for ratings and fuel data)

  • External dependencies: Zero API keys required -- all data sources are free public APIs


License

MIT


Built for mcp.vin

-
security - not tested
A
license - permissive license
-
quality - not tested

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/keptlive/vin-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server