NVD MCP Server
NVD MCP Server
A Model Context Protocol (MCP) server that lets AI assistants like Claude, Cursor, and Gemini search the National Vulnerability Database (NVD) for security vulnerabilities and their change history — in plain English, no API knowledge required.
Ask your AI assistant things like:
"Find critical CVEs published this month"
"What vulnerabilities affect OpenSSL 3.0.0?"
"Look up Log4Shell"
"Show me the full change history for CVE-2021-44228"
"Which Log4Shell changes came from NVD analysts?"
How it works
sequenceDiagram
actor User
participant Agent as AI Assistant<br/>(Claude / Cursor / Gemini)
participant MCP as NVD MCP Server
participant NVD as NVD API<br/>(nvd.nist.gov)
User->>Agent: "Find critical CVEs in Apache Log4j"
Agent->>MCP: search_cves(keyword_search="Apache Log4j",<br/>cvss_v3_severity="CRITICAL")
MCP->>NVD: GET /rest/json/cves/2.0<br/>?keywordSearch=Apache+Log4j<br/>&cvssV3Severity=CRITICAL<br/>&apiKey=...
NVD-->>MCP: Raw vulnerability JSON
MCP->>MCP: Validate & condense response
MCP-->>Agent: id, description, CVSS score,<br/>CWEs, references, KEV status
Agent-->>User: Formatted summary of matching CVEsThe server sits between your AI assistant and the NVD API. It:
Receives natural-language-driven tool calls from the AI
Translates them into authenticated NVD API requests
Validates the raw response against strict data models
Returns a clean, condensed result the AI can reason about
Tools
search_cves
Search the NVD CVE database with any combination of filters. Returns up to 10 CVEs per page, each with id, published date, status, description, CVSS score, CWEs, top 5 references, and CISA KEV data.
search_cve_history
Search the NVD CVE Change History API to see every modification made to a CVE record — description updates, CVSS score changes, CWE remaps, CPE configuration changes, KEV additions, and more. Returns a paginated list of change events with full before/after details.
Prerequisites
Python 3.11+
uv — fast Python package manager
An NVD API key (free, takes ~1 hour to receive)
Step 1 — Get an NVD API key
The NVD API is free and open, but an API key increases your rate limit from 5 requests/30 seconds to 50 requests/30 seconds.
Enter your email address and submit the form
Check your email — you'll receive your key within an hour
Copy the key, you'll need it in the next step
Step 2 — Install the server
git clone https://github.com/Alig1493/nvd-mcp-server.git
cd nvd-mcp-server
uv syncStep 3 — Configure your API key
Create a .env file in the project root:
NVD_API_KEY=your-api-key-hereThat's the only required setting. The NVD API URLs are pre-configured.
Step 4 — Connect to your AI assistant
The server supports two transports: local stdio (spawn a process) and remote Streamable HTTP (connect over a network).
Option A: Local Process Setup (stdio)
Great for single-user local workflows where your assistant spawns the server directly.
Claude Desktop
Open your Claude Desktop config file:
OS | Path |
macOS |
|
Windows |
|
Add the following inside the "mcpServers" object:
{
"mcpServers": {
"nvd-mcp-server": {
"type": "stdio",
"command": "uv",
"args": [
"--directory", "/absolute/path/to/nvd-mcp-server",
"run", "nvd-mcp-server",
"--transport", "stdio"
],
"env": {
"NVD_API_KEY": "your-api-key-here"
}
}
}
}Replace /absolute/path/to/nvd-mcp-server with your local repository root. Restart Claude Desktop.
Claude Code (CLI)
claude mcp add nvd-mcp-server \
--command uv \
--args "--directory /absolute/path/to/nvd-mcp-server run nvd-mcp-server --transport stdio" \
--env NVD_API_KEY=your-api-key-hereCursor
Open Cursor → Settings → MCP, then add:
Name:
nvd-mcp-serverType:
commandCommand:
uv --directory /absolute/path/to/nvd-mcp-server run nvd-mcp-server --transport stdio
Option B: Cloud or Container Setup (Streamable HTTP)
Perfect for shared deployments or clients that connect over a network.
Start the server:
docker compose up --build -dConnect your client using the /mcp endpoint:
{
"mcpServers": {
"nvd-mcp-server": {
"type": "http",
"url": "http://localhost:8000/mcp"
}
}
}The
NVD_API_KEYis read from your.envfile automatically by Docker Compose.
Custom port:
docker run -d -p 9090:8000 --env-file .env nvd-mcp-server-app \
nvd-mcp-server --transport http --host 0.0.0.0 --port 9090Example prompts
Look up a specific CVE
"What is CVE-2021-44228?"
CVE-2021-44228 — Log4Shell
Published: 2021-12-10 | Status: Analyzed
CVSS: 10.0 CRITICAL (CVSSv3.1) | AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H
Apache Log4j2 2.0-beta9 through 2.15.0 JNDI features do not protect against
attacker-controlled LDAP endpoints. An attacker who can control log messages
can execute arbitrary code loaded from a remote server.
CWEs: CWE-20, CWE-400, CWE-502, CWE-917
CISA KEV: Added 2021-12-10 · Due 2021-12-24Find vulnerabilities for a product
"What are the critical vulnerabilities affecting OpenSSL 3.0.0?"
Search by keyword
"Find recent CVEs related to remote code execution in Windows"
"Show me SQL injection vulnerabilities from the last 6 months"
Filter by severity
"List high and critical CVEs published in January 2025"
"Find all CVEs in CISA's Known Exploited Vulnerabilities catalog from Q1 2023"
Track CVE changes over time
"Show me the change history for CVE-2021-44228"
"What Initial Analysis events happened in January 2024?"
"Show me all CVE CISA KEV updates from last month"
Paginate through results
"Show me the next page of results"
Every response includes a pagination_hint telling the assistant exactly how many results remain and how to fetch the next page.
Available filters (reference)
search_cves
Filter | What it does | Example value |
| Look up a specific CVE |
|
| Search descriptions |
|
| Exact phrase match |
|
| Filter by CVSSv3 severity |
|
| Filter by CVSSv2 severity |
|
| Match a CVSSv3 vector string |
|
| Filter by weakness type |
|
| Filter by affected product |
|
| Only confirmed vulnerable configs |
|
| Broad product match |
|
| Published date range |
|
| Last modified date range |
|
| CISA KEV addition date range |
|
| Only KEV catalog CVEs |
|
| Exclude rejected CVEs |
|
| Filter by tag |
|
| Pagination offset |
|
search_cve_history
Filter | What it does | Example value |
| Full history for a specific CVE |
|
| Filter by change event type |
|
| Date range of changes (max 120 days) |
|
| Results per page (max 5,000) |
|
| Pagination offset |
|
Supported event names: CVE Received, Initial Analysis, Reanalysis, CVE Modified, Modified Analysis, CVE Translated, Vendor Comment, CVE Source Update, CPE Deprecation Remap, CWE Remap, Reference Tag Update, CVE Rejected, CVE Unrejected, CVE CISA KEV Update, Data Remediation, CVE Status Change
Notes
CVSSv2: NVD stopped generating CVSSv2 data on 2022-07-13.
cvss_v2_severityandcvss_v2_metricsfilters only match pre-2022 CVEs.
Date ranges: The maximum allowable range for any date filter is 120 consecutive days. Requests spanning a longer period will be rejected by the NVD API.
Rate limits: Without an API key you are limited to 5 requests per 30 seconds. Get a free key at https://nvd.nist.gov/developers/request-an-api-key.
Configuration options
Variable | Default | Description |
| (required) | Your NVD API key |
|
| NVD CVE endpoint |
|
| NVD history endpoint |
|
| Per-request HTTP timeout in seconds |
|
| Total retry budget in seconds |
Running the tests
End-to-end stdio tests (covers all search_cves and search_cve_history parameters):
uv run src/scripts/test_stdio_connection.pyHTTP smoke test (requires the Docker container to be running):
uv run src/scripts/test_http_connection.py
uv run src/scripts/test_http_connection.py --url http://localhost:9090/mcpTo run the tests in CI, add NVD_API_KEY as a repository secret in GitHub → Settings → Secrets → Actions.
Troubleshooting
The tool doesn't appear in my AI assistant
Restart the application after editing the config file. Check that the path to the repo is absolute (not ~ or relative).
NVD_API_KEY validation error on startup
The server requires an API key. Make sure NVD_API_KEY is set either in .env or in the "env" block of your MCP config.
Requests timing out
The NVD API can be slow for broad queries. Try narrowing your search with additional filters. You can also increase the timeout: TOTAL_TIMEOUT=120.
Rate limit errors (HTTP 403) Without an API key you are limited to 5 requests per 30 seconds. Get a free key at https://nvd.nist.gov/developers/request-an-api-key.
This server cannot be installed
Maintenance
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/Alig1493/nvd-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server