CLI tool to navigate and manage MCP registry servers
Project description
MCP Registry CLI
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:
↑/↓ork/j- Navigate servers within current page←/→orp/n- Navigate between pages (30 servers per page)Enter- View detailed server informationi- Install selected servers- Search servers by name or descriptionf- Filter servers by status (active, inactive, deprecated)c- Clear all filters and searchr- Refresh server listh- Show/hide help panelq- 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-runto 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
--limitparameter
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.
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
Author
Loreto Parisi - loretoparisi@gmail.com
Acknowledgments
- Built for the Model Context Protocol (MCP) ecosystem
- Uses the official MCP Registry API
- Powered by Rich for beautiful terminal output
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f0216186851786a334d8237313981306972e155d015204f424c88cd6dc1ef9cd
|
|
| MD5 |
e02cd528a769a2eff950187b2c5b2299
|
|
| BLAKE2b-256 |
f1fff914287f7cb38df74d353cb6a78f0ceed24af5ce92b1d57ce7d9429b6f51
|
File details
Details for the file mcp_registry_cli-0.3.0-py3-none-any.whl.
File metadata
- Download URL: mcp_registry_cli-0.3.0-py3-none-any.whl
- Upload date:
- Size: 27.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
808031293c64f9ef718913f045de12b7f1f711a80a71b33b5b62e64314da39a5
|
|
| MD5 |
679c5c0a8b8328676563f5a9b4553aa1
|
|
| BLAKE2b-256 |
7da536ee4fc2702cefb7f328668ccc08e53934785ea668c06bc25aea61260c9d
|