Skip to main content

๐Ÿ AI-powered Python package intelligence - search, analyze, and understand PyPI packages through MCP

Project description

๐Ÿ MCP-PyPI

PyPI License Python Downloads Powered by FastMCP

A security-focused Model Context Protocol (MCP) server that helps AI agents write safer Python code. Search packages, scan for vulnerabilities, audit dependencies, and ensure security across your entire Python project.

โœจ What is MCP-PyPI?

MCP-PyPI is a security-focused Model Context Protocol server that empowers AI assistants to write safer Python code. Beyond basic package information, it provides comprehensive vulnerability scanning, dependency auditing, and proactive security recommendations to ensure AI-generated code uses secure, up-to-date dependencies.

๐Ÿ›ก๏ธ Security First: Every tool is designed to encourage security best practices, from checking vulnerabilities before suggesting packages to scanning entire project dependency trees for hidden risks.

๐ŸŽฏ Key Features

  • ๐Ÿ›ก๏ธ Comprehensive Security Scanning - Check vulnerabilities using OSV database across packages, dependencies, and entire projects
  • ๐Ÿ” Security-Aware Package Search - Find safe packages from 500,000+ options with vulnerability status
  • ๐Ÿ“‹ Project-Wide Security Audits - Scan requirements.txt, pyproject.toml, and installed environments
  • ๐Ÿ”— Deep Dependency Analysis - Detect vulnerabilities in transitive dependencies others might miss
  • ๐Ÿšจ Proactive Security Alerts - Get warnings before adding vulnerable packages to projects
  • ๐Ÿ“Š Risk Assessment & Scoring - Security scores, fix time estimates, and prioritized remediation plans
  • โšก Smart Caching - Fast vulnerability checks with configurable TTL for different data types
  • ๐Ÿš€ Version Management - Track releases, compare versions, identify security updates
  • ๐Ÿค– LLM-Safe Tool Annotations - FastMCP 2.14.4 powered with tool annotations for safe AI agent interactions
  • ๐Ÿงฉ Modular Architecture - Clean separation of tools, operations, and CLI for maintainability

๐Ÿค” Why Security Matters

When AI assistants suggest Python packages, they might unknowingly recommend packages with known vulnerabilities. MCP-PyPI ensures that:

  • Before Installation: AI checks for vulnerabilities before suggesting any package
  • During Development: Continuous scanning catches new vulnerabilities in existing dependencies
  • Before Deployment: Comprehensive audits ensure production code is secure
  • Transitive Safety: Hidden vulnerabilities in dependencies-of-dependencies are detected

๐Ÿš€ Quick Start

System Requirements

  • Python 3.10 or higher
  • pip package manager
  • Virtual environment (recommended)
  • fastmcp>=2.14.4 (installed automatically)

Installation

# Basic installation
pip install mcp-pypi

# With HTTP transport support
pip install "mcp-pypi[http]"

# With all features
pip install "mcp-pypi[all]"

Running the Server

# Start with default stdio transport (for Claude Desktop)
mcp-pypi serve

# Alternative stdio command (for compatibility)
mcp-pypi stdio

# Start with HTTP transport
mcp-pypi serve --transport http

# With custom cache directory
mcp-pypi serve --cache-dir ~/.pypi-cache

๐Ÿค– Using with Claude Desktop

Add to your Claude Desktop configuration (claude.json):

{
  "servers": {
    "pypi": {
      "command": "mcp-pypi",
      "args": ["serve"],
      "description": "Access Python package information from PyPI"
    }
  }
}

// Alternative using stdio command (equivalent to above)
{
  "servers": {
    "pypi": {
      "command": "mcp-pypi",
      "args": ["stdio"],
      "description": "Access Python package information from PyPI"
    }
  }
}

๐Ÿ–ฅ๏ธ Using with Claude Code (Terminal)

Add the MCP server to Claude Code:

# Add the server (using serve command)
claude mcp add mcp-pypi -- mcp-pypi serve

# Alternative using stdio command
claude mcp add mcp-pypi -- mcp-pypi stdio

# The server will be available in your next Claude Code session

๐Ÿ–ฑ๏ธ Using with Cursor IDE

Cursor IDE supports MCP servers through configuration files. You can configure mcp-pypi either globally (available in all projects) or per-project.

Quick Setup via Settings UI

  1. Open Cursor Settings (Cmd+, on Mac, Ctrl+, on Windows/Linux)
  2. Navigate to Features > Model Context Protocol
  3. Click Add New MCP Server
  4. Enter the configuration shown below

Configuration File Setup

Global Configuration (available in all projects):

Platform Location
macOS/Linux ~/.cursor/mcp.json
Windows C:\Users\YourUsername\.cursor\mcp.json

Project Configuration (project-specific): Create .cursor/mcp.json in your project root.

Configuration Example

Add mcp-pypi to your mcp.json file:

{
  "mcpServers": {
    "mcp-pypi": {
      "command": "mcp-pypi",
      "args": ["serve"]
    }
  }
}

With custom options:

{
  "mcpServers": {
    "mcp-pypi": {
      "command": "mcp-pypi",
      "args": ["serve", "--log-level", "DEBUG"],
      "env": {
        "PYPI_CACHE_DIR": "/path/to/cache"
      }
    }
  }
}

Verification

  1. Restart Cursor completely after adding the configuration
  2. Open any project and switch to Agent Mode (not Ask Mode)
  3. The MCP tools should appear in the tools list
  4. Test by asking: "Search for web scraping packages on PyPI"

Troubleshooting Cursor

Issue Solution
Tools not appearing Ensure Cursor is in Agent Mode, not Ask Mode
Server not starting Check mcp-pypi is installed and in PATH
Configuration errors Open Output panel (Cmd+Shift+U) and select "MCP Logs"
Server crashes Toggle server off/on in Settings without removing config

๐Ÿ› ๏ธ Available Tools

Package Discovery

  • search_packages - ๐Ÿ” Search PyPI to discover Python packages
  • get_package_info - ๐Ÿ“ฆ Get comprehensive package details
  • check_package_exists - โœ… Verify if a package exists on PyPI

Version Management

  • get_latest_version - ๐Ÿš€ Check the latest available version
  • get_package_releases - ๐Ÿ“… Get detailed release information for a package
  • list_package_versions - ๐Ÿ“š List all available versions
  • compare_versions - ๐Ÿ”„ Compare two package versions

Dependency Analysis

  • get_dependencies - ๐Ÿ”— Analyze package dependencies
  • get_dependency_tree - ๐ŸŒณ Visualize complete dependency tree
  • check_vulnerabilities - ๐Ÿ›ก๏ธ Scan for security vulnerabilities using OSV database
  • scan_dependency_vulnerabilities - ๐Ÿ›ก๏ธ๐Ÿ” Deep scan entire dependency tree for vulnerabilities

Project Management

  • check_requirements_txt - ๐Ÿ“‹๐Ÿ›ก๏ธ Security audit requirements.txt files
  • check_pyproject_toml - ๐ŸŽฏ๐Ÿ›ก๏ธ Security audit pyproject.toml dependencies
  • scan_installed_packages - ๐Ÿ›ก๏ธ๐Ÿ’ป Scan virtual/system environments for vulnerabilities
  • security_audit_project - ๐Ÿ›ก๏ธ๐Ÿ”๐Ÿšจ Comprehensive project-wide security audit
  • quick_security_check - ๐Ÿšฆ Quick pass/fail security check for CI/CD
  • get_security_report - ๐Ÿ›ก๏ธ๐Ÿ“Š Beautiful, color-coded security report

Statistics & Info

  • get_package_stats - ๐Ÿ“Š Get download statistics
  • get_package_metadata - ๐Ÿ“‹ Access complete metadata
  • get_package_documentation - ๐Ÿ“– Find documentation links
  • get_package_changelog - ๐Ÿ“ Get changelog information from GitHub releases

๐Ÿ’ก Example Usage

Once configured, you can ask Claude:

  • "Search for web scraping packages on PyPI"
  • "What's the latest version of Django?"
  • "Check if my requirements.txt has any outdated packages"
  • "Show me the dependencies for FastAPI"
  • "Find popular data visualization libraries"
  • "Compare pandas version 2.0.0 with 2.1.0"

๐Ÿ”ง Advanced Configuration

Environment Variables

# Custom cache directory
export PYPI_CACHE_DIR=/path/to/cache

# Cache TTL (seconds)
export PYPI_CACHE_TTL=3600

# Vulnerability cache TTL (seconds) - default 1 hour
export PYPI_VULNERABILITY_CACHE_TTL=3600

# Custom user agent
export PYPI_USER_AGENT="MyApp/1.0"

Programmatic Usage

from mcp_pypi.server import PyPIMCPServer
from mcp_pypi.core.models import PyPIClientConfig

# Custom configuration
config = PyPIClientConfig(
    cache_dir="/tmp/pypi-cache",
    cache_ttl=7200,
    cache_strategy="hybrid"
)

# Create and run server
server = PyPIMCPServer(config=config)
server.run(transport="http", host="0.0.0.0", port=8080)

๐Ÿ“Š Performance

  • Intelligent Caching: Hybrid memory/disk caching with LRU/LFU/FIFO strategies
  • Concurrent Requests: Async architecture for parallel operations
  • Minimal Overhead: Direct PyPI API integration
  • Configurable TTL: Control cache duration based on your needs

๐Ÿ›ก๏ธ Security & Caching

Vulnerability Data Caching

Vulnerability checks are cached to improve performance and reduce API load:

  • Default TTL: 1 hour (3600 seconds)
  • Configurable: Use PYPI_VULNERABILITY_CACHE_TTL environment variable
  • Cache Key: Based on package name + version
  • OSV API: Queries are cached to avoid repeated lookups

Why Caching Matters

  1. Performance: Vulnerability checks can be slow, caching makes subsequent checks instant
  2. Rate Limiting: Prevents hitting OSV API rate limits during large scans
  3. Consistency: Ensures consistent results during a security audit
  4. Offline Support: Cached results available even if OSV API is unreachable

Cache Management

# Clear all caches
mcp-pypi cache clear

# View cache statistics
mcp-pypi cache stats

# Set shorter TTL for development (5 minutes)
export PYPI_VULNERABILITY_CACHE_TTL=300

๐Ÿ–ฅ๏ธ CLI Usage

MCP-PyPI includes a full-featured command-line interface for direct package operations:

Help and Documentation

# Show version
mcp-pypi --version

# Display README documentation
mcp-pypi --readme

# Show changelog
mcp-pypi --changelog

# Get connection examples
mcp-pypi serve --help-connecting
mcp-pypi stdio --help-connecting

Package Information

# Search for packages
mcp-pypi search "web scraping"

# Get package info
mcp-pypi package info requests

# Check latest version
mcp-pypi package version django

# List all versions
mcp-pypi package releases numpy

# Get dependencies
mcp-pypi package dependencies flask

# Compare versions
mcp-pypi package compare pandas 2.0.0 2.1.0

Security Checks

# Check requirements file
mcp-pypi check-requirements /path/to/requirements.txt

# View package statistics
mcp-pypi stats downloads requests

Cache Management

# Clear cache
mcp-pypi cache clear

# View cache statistics
mcp-pypi cache stats

โ“ Troubleshooting

Common Issues

Connection Issues with stdio

  • Ensure you're using the absolute path to mcp-pypi in your configuration
  • Try using mcp-pypi stdio instead of mcp-pypi serve for better compatibility
  • Check logs with --log-level DEBUG for detailed error messages

Token Limit Errors

  • Some operations like changelog retrieval are automatically limited to prevent token overflow
  • Use more specific queries when searching for packages
  • Check individual packages rather than bulk operations

Cache Issues

  • Clear cache with mcp-pypi cache clear if you see stale data
  • Adjust cache TTL with environment variables for your use case
  • Default cache location is ~/.cache/mcp-pypi/

Import Errors

  • Ensure you have Python 3.10+ installed
  • Install with pip install "mcp-pypi[all]" for all dependencies
  • Use a virtual environment to avoid conflicts

๐Ÿค Contributing

Contributions are welcome! Please check out our Contributing Guide for details.

Development Setup

# Clone the repository
git clone https://github.com/kimasplund/mcp-pypi.git
cd mcp-pypi

# Install in development mode
pip install -e ".[dev]"

# Run tests
pytest

# Run with debug logging
mcp-pypi serve --log-level DEBUG

๐Ÿ“„ License

This project is dual-licensed:

  • Open Source: MIT License for personal, educational, and non-profit use - see LICENSE
  • Commercial: Commercial License required for business use - see LICENSE-COMMERCIAL

Quick License Guide:

  • โœ… Free to use: Personal projects, education, non-profits, open source
  • ๐Ÿ’ฐ Commercial license required: For-profit companies, commercial products, consulting
  • ๐Ÿ“ง Contact: kim.asplund@gmail.com for commercial licensing

๐Ÿ™ Acknowledgments

๐Ÿ“ž Support


Made with โค๏ธ for the Python and AI communities

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mcp_pypi-3.0.0.tar.gz (126.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_pypi-3.0.0-py3-none-any.whl (116.3 kB view details)

Uploaded Python 3

File details

Details for the file mcp_pypi-3.0.0.tar.gz.

File metadata

  • Download URL: mcp_pypi-3.0.0.tar.gz
  • Upload date:
  • Size: 126.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mcp_pypi-3.0.0.tar.gz
Algorithm Hash digest
SHA256 0d54e08972f4a0ef7706de7a5169ca44c8312b64a3cff08c0968792380f70c75
MD5 86c346254a4633a135574210def4fd45
BLAKE2b-256 01e5449b02994d45c754084c2522d3eb0828a628a89a6cb8c634a560c4f32acf

See more details on using hashes here.

File details

Details for the file mcp_pypi-3.0.0-py3-none-any.whl.

File metadata

  • Download URL: mcp_pypi-3.0.0-py3-none-any.whl
  • Upload date:
  • Size: 116.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mcp_pypi-3.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4ce14722ed35ba71b45c280880b4c4efdbda7b8aede8c02e2ccebd65b4374f4b
MD5 74c60f5f8f2bbfe6e930f539d84591c7
BLAKE2b-256 6e70eb3ba922b8e2b8687723892fa8eaa321a916d740d76b5a827d3c05f23b5b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page