Skip to main content
Glama

CWE Search MCP

A Python-based interface to MITRE's Common Weakness Enumeration (CWE) database via the official API, enabling seamless vulnerability research and integration with MCP-compatible systems.

Python Version License: MIT CWE API fastmcp uv

Twitter LinkedIn GitHub

Overview

The CWE Search MCP provides a robust Python implementation for interacting with MITRE's Common Weakness Enumeration (CWE) database through its official API. Designed for security researchers, developers, and vulnerability analysts, this mcp enables efficient querying of vulnerability information and integrates seamlessly with MCP-compatible systems using stdio transport.

This solution solves the problem of fragmented vulnerability research by providing a unified interface to:

  • Retrieve detailed CWE information programmatically

  • Explore vulnerability relationships and hierarchies

  • Integrate CWE data into security tooling and workflows

  • Automate vulnerability analysis and reporting

Related MCP server: MITRE ATT&CK Mapper MCP

Key Features

  • Comprehensive Vulnerability Lookup: Retrieve detailed information by CWE ID

  • Intelligent Search: Find vulnerabilities by keyword across descriptions

  • Taxonomy Navigation: Explore CWE categories and views

  • Relationship Mapping:

    • Parent/child vulnerability relationships

    • Full ancestor/descendant hierarchies

    • View-filtered relationship analysis

  • Automatic Normalization: Handles CWE IDs with or without "CWE-" prefix

  • Zero Configuration: No authentication required for MITRE's public API

  • MCP Integration: Ready for stdio transport with MCP-compatible systems

  • Batch Processing: Retrieve multiple vulnerabilities in single requests

Implemented API Endpoints

The mcp implements the following MITRE CWE API endpoints:

Endpoint

Description

/cwe/version

Get CWE content version information

/cwe/{id}

Retrieve metadata for specified CWE ID(s)

/weakness/{id(s)}

Get weaknesses by ID(s) or all weaknesses

/cwe/category/{id(s)}

Retrieve categories by ID(s) or all categories

/cwe/view/{id(s)}

Get views by ID(s) or all views

/cwe/{id}/parents

Get parents of a weakness (view-filtered)

/cwe/{id}/children

Get children of a weakness (view-filtered)

/cwe/{id}/ancestors

Get ancestors of a weakness (view-filtered)

/cwe/{id}/descendants

Get descendants of a weakness (view-filtered)

Getting Started

Prerequisites

  • Python 3.10+

  • uv package manager

Installation

  1. Clone the repository:

    git clone https://github.com/Bilel-Eljaamii/cwe-search_mcp.git
    cd cwe-search_mcp
  2. Install dependencies:

    pip install requests fast-mcp

Usage Guide

Standalone Execution

Run the mcp as a standalone module:

DANGEROUSLY_OMIT_AUTH=true mcp dev main.py

Output:

[06/28/25 12:46:09] INFO     Starting cwe-search_mcp
Starting MCP inspector...
⚙ Proxy server listening on 127.0.0.1:6277
⚠  WARNING: Authentication is disabled. This is not recommended.
New STDIO connection request
STDIO transport: command=/usr/bin/uv, args=run,--with,mcp,mcp,run,main.py
Created server transport
Created client transport
🔍 MCP Inspec

assets/img/demoMCPdev.png

MCP Client Integration

To integrate the CWE Search Service with your MCP client:

  1. Locate Configuration: Open your MCP client configuration file

  2. Update Path: Set CWE_SEARCH_SERVICE_PATH to the absolute path of your local installation directory

  3. Add to your mcp client configuration file, modify the 3."CWE_SEARCH_SERVICE_PATH" as you self dir.

"cwe-search_mcp": {
  "autoApprove": [],
  "disabled": false,
  "timeout": 60,
  "type": "stdio",
  "command": "uv",
  "args": [
    "--directory",
    "CWE_SEARCH_SERVICE_PATH",
    "run",
    "main.py"
  ]
}

AnythingLLM

assets/img/AnythingLLM_integraton.png

Cline / VSCode

assets/img/Cline_integraton.png

Key Notes

  • Authentication: No credentials required - MITRE's CWE API is publicly accessible

  • Input Normalization: MCP automatically handles CWE ID formats:

    • 79 → Normalized to 79

    • CWE-79 → Normalized to 79

    • cwe79 → Normalized to 79

  • Batch Processing: Comma-separated IDs supported for most endpoints

  • all Keyword: Retrieve all items for weakness, category, and view endpoints

Dependencies

  • requests - HTTP library for API communication

  • fastmcp - The fast, Pythonic way to build MCP servers and clients.

# Using uv (recommended)
uv init
uv venv
source ./venv/bin/activate
uv pip install "mcp[cli]" "requests"

Contributing

We welcome contributions! Please follow these steps:

  1. Fork the repository

  2. Create your feature branch (git checkout -b feature/your-feature)

  3. Commit your changes (git commit -am 'Add some feature')

  4. Push to the branch (git push origin feature/your-feature)

  5. Open a pull request

Please ensure your code follows PEP 8 style guidelines and includes appropriate tests.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgements & Resources


Empower your vulnerability research with direct access to MITRE's CWE database through this lightweight, integration-ready MCP. Contribute, customize, and enhance your security workflows today!

A
license - permissive license
-
quality - not tested
D
maintenance

Maintenance

Maintainers
Response time
Release cycle
Releases (12mo)
Commit activity

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

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/Bilel-Eljaamii/cwe-search_mcp'

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