Skip to main content

CLI tool to navigate and manage MCP registry servers

Project description

MCP Registry CLI

PyPI version Python 3.8+ License: MIT

A command-line interface for navigating and managing servers from the Model Context Protocol (MCP) registry.

Features

  • 🔍 Browse MCP servers with intelligent pagination (30 servers per page)
  • 📊 Filter and sort servers by status, name, description
  • 📋 View detailed information including packages and repositories
  • 📦 Install servers via CLI with npm/pip support
  • 🎨 Rich terminal UI with colors, tables, and beautiful formatting
  • ⌨️ Interactive navigation with full keyboard support
  • 🚀 Smart pagination with left/right arrow keys and p/n shortcuts
  • 🔗 Direct API access to MCP Registry

Installation

📦 Available on PyPI: https://pypi.org/project/mcp-registry-cli/

Prerequisites

  • Python 3.8 or higher
  • pip package manager

Recommended: Using Virtual Environment

# Create and activate virtual environment
python3 -m venv mcp-registry-env
source mcp-registry-env/bin/activate  # On Windows: mcp-registry-env\Scripts\activate

# Install from PyPI
pip install mcp-registry-cli

System-wide Installation

# Install directly from PyPI
pip install mcp-registry-cli

From Source (Development)

# Clone the repository
git clone https://github.com/loretoparisi/mcp-registry-cli.git
cd mcp-registry-cli

# Create virtual environment
python3 -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate

# Install in development mode
pip install -e .

# Or with development dependencies
pip install -e ".[dev]"

Quick Start

Interactive Mode (Recommended)

# Start interactive CLI with keyboard navigation
mcp-registry-cli

# Alternative ways to start interactive mode
mcp-registry --interactive
mcp-registry interactive

Interactive Controls:

  • ↑/↓ or k/j - Navigate servers within current page
  • ←/→ or p/n - Navigate between pages (30 servers per page)
  • Enter - View detailed server information
  • i - Install selected server
  • s - Search servers by name or description
  • f - Filter servers by status (active, inactive, deprecated)
  • c - Clear all filters and search
  • r - Refresh server list
  • h - Show/hide help panel
  • q - Quit application

Pagination Features:

  • Smart page navigation: 30 servers per page with intuitive controls
  • Page indicators: Shows current page with "+" when more pages available (e.g., "Page 2+")
  • Cross-platform: Arrow keys work on Windows, macOS, and Linux
  • Fallback support: Works in any terminal, with or without Rich library

Command Line Mode

# List first 10 servers
mcp-registry list --limit 10

# Search for GitHub-related servers
mcp-registry list --search github

# Show detailed information about a server
mcp-registry show io.github.domdomegg/airtable-mcp-server

# Preview installation commands
mcp-registry install io.github.domdomegg/airtable-mcp-server --dry-run

# Install a server (requires appropriate package manager)
mcp-registry install io.github.domdomegg/airtable-mcp-server

Command Reference

List Servers

mcp-registry list [OPTIONS]

Options:
  --limit INTEGER         Number of servers to display (default: 30)
  --cursor TEXT          Pagination cursor for next page
  --search TEXT          Search servers by name or description
  --status TEXT          Filter by status (active, inactive, deprecated)
  --sort [name|status|description]  Sort by field (default: name)
  --reverse              Reverse sort order

Show Server Details

mcp-registry show <server-name>

Example:
mcp-registry show ai.waystation/gmail

Install Server

mcp-registry install <server-name> [OPTIONS]

Options:
  --package-manager [npm|pip|auto]  Package manager to use (default: auto)
  --dry-run                        Show commands without executing

Examples

Explore the Registry

# List all active servers
mcp-registry list --status active

# Find database-related servers
mcp-registry list --search database --limit 5

# Browse with pagination (30 servers per page)
mcp-registry list --limit 30
# Use the cursor from output for next page
mcp-registry list --cursor <next-cursor>

Get Server Information

# View comprehensive server details
mcp-registry show com.pga/pga-golf

# Check available installation packages
mcp-registry show io.github.DeanWard/HAL

Install Servers

# Preview installation
mcp-registry install xcodebuildmcp --dry-run

# Install with specific package manager
mcp-registry install hal-mcp --package-manager npm

# Auto-detect and install
mcp-registry install reddit-research-mcp

Programmatic Usage

from mcp_registry_cli.api import MCPRegistryAPI

# Initialize API client
api = MCPRegistryAPI()

# List servers
result = api.list_servers(limit=10)
for server in result['servers']:
    print(f"{server.name}: {server.description}")

# Get server details
server = api.get_server_details("ai.waystation/gmail")
print(f"Status: {server.status}")
if server.packages:
    print("Available packages:")
    for pkg in server.packages:
        print(f"  - {pkg.get('registry')}: {pkg.get('package')}")

# Search servers
result = api.search_servers("github", limit=5)
print(f"Found {len(result['servers'])} GitHub-related servers")

Troubleshooting

Virtual Environment Issues

If you encounter permission errors, ensure you're using a virtual environment:

python3 -m venv mcp-registry-env
source mcp-registry-env/bin/activate
pip install --upgrade pip
pip install mcp-registry-cli

Package Installation

If server installation fails, check that you have the required package manager:

  • npm servers: Ensure Node.js and npm are installed
  • pip servers: Ensure Python and pip are available
  • Use --dry-run to preview commands before execution

API Issues

If you encounter API errors:

  • Check your internet connection
  • The MCP Registry API may be temporarily unavailable
  • Try reducing the --limit parameter

Development

Setup Development Environment

# Clone repository
git clone https://github.com/loretoparisi/mcp-registry-cli.git
cd mcp-registry-cli

# Create virtual environment
python3 -m venv venv
source venv/bin/activate

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

Development Commands

# Run tests
pytest

# Format code
black src/

# Type checking
mypy src/

# Test CLI locally
python3 -m src.mcp_registry_cli.cli --help

Requirements

  • Python 3.8+
  • click >= 8.0.0
  • requests >= 2.25.0
  • rich >= 12.0.0
  • tabulate >= 0.9.0

License

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

License Summary

  • ✅ Free to use for commercial and non-commercial purposes
  • ✅ Modify and distribute as needed
  • ✅ Include in your own projects
  • ✅ Must include copyright notice

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

Author

Loreto Parisi - loretoparisi@gmail.com

Acknowledgments

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_registry_cli-0.3.0.tar.gz (22.7 kB view details)

Uploaded Source

Built Distribution

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

mcp_registry_cli-0.3.0-py3-none-any.whl (27.0 kB view details)

Uploaded Python 3

File details

Details for the file mcp_registry_cli-0.3.0.tar.gz.

File metadata

  • Download URL: mcp_registry_cli-0.3.0.tar.gz
  • Upload date:
  • Size: 22.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.3

File hashes

Hashes for mcp_registry_cli-0.3.0.tar.gz
Algorithm Hash digest
SHA256 f0216186851786a334d8237313981306972e155d015204f424c88cd6dc1ef9cd
MD5 e02cd528a769a2eff950187b2c5b2299
BLAKE2b-256 f1fff914287f7cb38df74d353cb6a78f0ceed24af5ce92b1d57ce7d9429b6f51

See more details on using hashes here.

File details

Details for the file mcp_registry_cli-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for mcp_registry_cli-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 808031293c64f9ef718913f045de12b7f1f711a80a71b33b5b62e64314da39a5
MD5 679c5c0a8b8328676563f5a9b4553aa1
BLAKE2b-256 7da536ee4fc2702cefb7f328668ccc08e53934785ea668c06bc25aea61260c9d

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