MCP server for Pi-hole DNS server interactions
Project description
Pi-hole MCP Server
A Model Context Protocol (MCP) server for interacting with Pi-hole DNS servers from AI assistants like Cursor. This allows you to manage your Pi-hole directly through natural language commands in your IDE.
Universal Compatibility: Works with both legacy and modern Pi-hole installations, automatically detecting the API version and using the appropriate authentication method.
Features
- ๐ Secure Credential Management: Encrypted storage of Pi-hole credentials using system keyring
- ๐ฏ Easy Setup: Simple CLI-based configuration and authentication
- ๐ Rich MCP Integration: Full support for Pi-hole operations through the MCP protocol
- ๐ Comprehensive Statistics: Access to detailed Pi-hole analytics and metrics
- ๐ ๏ธ Robust CLI: Complete command-line interface for Pi-hole management
- ๐ Security First: Secure API key handling and SSL verification
- ๐ Universal Compatibility: Supports both legacy and modern Pi-hole API versions
- ๐ค Automatic Detection: Automatically detects and adapts to your Pi-hole's API version
Installation
Prerequisites
- Python 3.10 or higher
- Access to a Pi-hole instance with either:
- Legacy Pi-hole: API key (found in Admin โ Settings โ API/Web interface โ Show API token)
- Modern Pi-hole: Web interface password (your admin login password)
- uv (recommended) or pip
Install from PyPI (Recommended)
# Install globally to ~/.local/
pip install --user pihole-mcp-server
# Or using uv
uv tool install pihole-mcp-server
Install from Source
# Clone the repository
git clone https://github.com/brettbergin/pihole-mcp-server.git
cd pihole-mcp-server
# Install with uv (recommended)
uv sync
uv pip install -e .
# Or with pip
pip install -e .
Quick Start
1. Configure Pi-hole Credentials
First, you need to authenticate with your Pi-hole instance:
pihole-mcp-cli login
The tool will automatically detect your Pi-hole's API version and prompt for appropriate credentials. If you don't provide specific authentication options, it will guide you through an interactive setup process.
For Legacy Pi-hole:
- Pi-hole hostname or IP: Your Pi-hole server address
- Port: Usually 80 (HTTP) or 443 (HTTPS)
- API key: Found in Pi-hole Admin โ Settings โ API/Web interface โ Show API token
- HTTPS: Whether to use secure connection
- SSL verification: Whether to verify SSL certificates
For Modern Pi-hole:
- Pi-hole hostname or IP: Your Pi-hole server address
- Port: Usually 8080 (HTTP) or 8443 (HTTPS)
- Web password: Your Pi-hole admin interface password
- HTTPS: Whether to use secure connection
- SSL verification: Whether to verify SSL certificates
Manual Authentication Method Selection
If you prefer to specify the authentication method manually:
# For legacy Pi-hole with API key
pihole-mcp-cli login --host 192.168.1.100 --api-key YOUR_API_KEY
# For modern Pi-hole with web password
pihole-mcp-cli login --host 192.168.1.100 --port 8080 --web-password YOUR_PASSWORD
# Read credentials from stdin (useful for automation)
echo "YOUR_API_KEY" | pihole-mcp-cli login --host 192.168.1.100 --api-key -
echo "YOUR_PASSWORD" | pihole-mcp-cli login --host 192.168.1.100 --port 8080 --web-password -
2. Test Your Connection
pihole-mcp-cli test
3. Use with Cursor or Other MCP Clients
Add the following to your Cursor MCP configuration:
{
"mcpServers": {
"pihole": {
"command": "pihole-mcp-server",
"args": []
}
}
}
4. Start Managing Pi-hole with AI
Once configured, you can use natural language commands in Cursor:
- "Disable Pi-hole for 30 minutes"
- "Show me Pi-hole statistics"
- "Enable Pi-hole blocking"
- "What are the top blocked domains?"
CLI Usage
Available Commands
| Command | Description |
|---|---|
login |
Configure and store Pi-hole credentials |
status |
Show Pi-hole status and statistics |
enable |
Enable Pi-hole DNS blocking |
disable |
Disable Pi-hole DNS blocking |
test |
Test connection and authentication |
info |
Show configuration information |
logout |
Remove stored credentials |
Login Command Options
| Option | Description | Example |
|---|---|---|
--host |
Pi-hole hostname or IP | --host 192.168.1.100 |
--port |
Pi-hole port number | --port 8080 |
--api-key |
API key for legacy Pi-hole | --api-key YOUR_API_KEY |
--web-password |
Web password for modern Pi-hole | --web-password YOUR_PASSWORD |
--use-https |
Use HTTPS connection | --use-https |
--no-verify-ssl |
Disable SSL verification | --no-verify-ssl |
--timeout |
Request timeout in seconds | --timeout 30 |
Examples
# Configure Pi-hole connection (interactive mode - auto-detects API version)
pihole-mcp-cli login --host 192.168.1.100
# Configure legacy Pi-hole with API key
pihole-mcp-cli login --host 192.168.1.100 --api-key YOUR_API_KEY --use-https
# Configure modern Pi-hole with web password
pihole-mcp-cli login --host 192.168.1.100 --port 8080 --web-password YOUR_PASSWORD
# Check current status
pihole-mcp-cli status
# Disable Pi-hole for 1 hour
pihole-mcp-cli disable --minutes 60
# Disable Pi-hole for 30 seconds
pihole-mcp-cli disable --seconds 30
# Enable Pi-hole
pihole-mcp-cli enable
# Show detailed help for a command
pihole-mcp-cli disable --help
MCP Tools
The MCP server provides the following tools for AI assistants:
Core Operations
pihole_status- Get current Pi-hole status and basic statisticspihole_enable- Enable Pi-hole DNS blockingpihole_disable- Disable Pi-hole DNS blocking (with optional duration)
Statistics and Analytics
System Information
pihole_version- Get Pi-hole version informationpihole_test_connection- Test connection and authentication
Configuration
API Version Detection
The tool automatically detects your Pi-hole's API version:
- Legacy Pi-hole: Uses
/admin/api.phpendpoint with API key authentication - Modern Pi-hole: Uses
/api/*endpoints with web password authentication
The detection process:
- Attempts to connect to modern API endpoints
- Falls back to legacy API if modern endpoints are not available
- Stores the detected version for future use
Credential Storage
Credentials are stored securely using:
- System Keyring (preferred): Uses your OS's secure credential storage
- Encrypted File (fallback): AES-encrypted file in
~/.local/share/pihole-mcp-server/
Configuration Directory
By default, configuration is stored in:
- Linux/macOS:
~/.local/share/pihole-mcp-server/ - Windows:
%LOCALAPPDATA%\pihole-mcp-server\
You can override this with the --config-dir option.
Environment Variables
| Variable | Description | Default |
|---|---|---|
PIHOLE_MCP_CONFIG_DIR |
Configuration directory | ~/.local/share/pihole-mcp-server |
Security
Credential Protection
- API keys and web passwords are never logged or displayed in plain text
- Stored using system keyring when available
- Fallback to AES-encrypted file storage
- Machine-specific encryption keys
- Automatic detection prevents credential type mismatches
SSL/TLS Support
- Full HTTPS support with certificate verification
- Option to disable SSL verification for self-signed certificates
- Secure connection handling with proper timeout management
Permissions
- Configuration files use restrictive permissions (600/700)
- No sensitive data in command line arguments
- Secure credential prompting
Troubleshooting
Common Issues
Connection Failed
# Test your connection
pihole-mcp-cli test
# Check your Pi-hole is accessible
ping your-pihole-ip
# Test legacy Pi-hole API
curl http://your-pihole-ip/admin/api.php
# Test modern Pi-hole API
curl http://your-pihole-ip:8080/api/stats/summary
Authentication Failed
For Legacy Pi-hole:
# Verify API key in Pi-hole admin interface
# Settings โ API / Web interface โ Show API token
# Re-login with correct API key
pihole-mcp-cli logout
pihole-mcp-cli login --host your-pihole-ip --api-key YOUR_API_KEY
For Modern Pi-hole:
# Use your web interface password (not API key)
pihole-mcp-cli logout
pihole-mcp-cli login --host your-pihole-ip --port 8080 --web-password YOUR_PASSWORD
Wrong Authentication Method
# If you get "unauthorized" errors, try the other authentication method
# Modern Pi-hole (usually port 8080) uses web password
# Legacy Pi-hole (usually port 80) uses API key
# Check which API version your Pi-hole uses
curl -I http://your-pihole-ip:8080/api/stats/summary # Modern
curl -I http://your-pihole-ip/admin/api.php # Legacy
MCP Server Not Responding
# Test MCP server directly
echo '{"jsonrpc": "2.0", "method": "tools/list", "id": 1}' | pihole-mcp-server
# Check if credentials are configured
pihole-mcp-cli info
Debug Mode
For debugging, you can run the MCP server with logging:
# Enable debug logging
export PYTHONPATH=src
python -m pihole_mcp_server.server
Reset Configuration
# Remove all stored credentials and configuration
pihole-mcp-cli logout
rm -rf ~/.local/share/pihole-mcp-server/
Development
Setup Development Environment
# Clone the repository
git clone https://github.com/brettbergin/pihole-mcp-server.git
cd pihole-mcp-server
# Install development dependencies
uv sync --dev
# Install pre-commit hooks
pre-commit install
# Run tests
pytest
# Type checking
mypy src/
# Code formatting
black src/
isort src/
Project Structure
pihole-mcp-server/
โโโ src/pihole_mcp_server/
โ โโโ __init__.py
โ โโโ cli.py # Command-line interface
โ โโโ credential_manager.py # Secure credential storage
โ โโโ pihole_client.py # Pi-hole API client
โ โโโ server.py # MCP server implementation
โโโ tests/ # Test suite
โโโ pyproject.toml # Project configuration
โโโ README.md # This file
Contributing
- 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
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
- Pi-hole - Network-wide ad blocking
- Model Context Protocol - AI assistant integration
- Cursor - AI-powered code editor
Support
- ๐ Bug Reports: GitHub Issues
- ๐ก Feature Requests: GitHub Discussions
- ๐ Documentation: GitHub Wiki
Made with โค๏ธ for the Pi-hole and AI assistant communities
Project details
Release history Release notifications | RSS feed
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 pihole_mcp_server-0.1.1.tar.gz.
File metadata
- Download URL: pihole_mcp_server-0.1.1.tar.gz
- Upload date:
- Size: 109.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
16e792415c87abf187a22b4b750f3c54887ee740ca6454b16626334a82398431
|
|
| MD5 |
87bea20ba303a2001456b5ce8d0e4ead
|
|
| BLAKE2b-256 |
e89a758a8a322d74351ace9a05ca6eaf3d4f3885e75b0893b9afbdd888f056ca
|
File details
Details for the file pihole_mcp_server-0.1.1-py3-none-any.whl.
File metadata
- Download URL: pihole_mcp_server-0.1.1-py3-none-any.whl
- Upload date:
- Size: 22.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4383f85c5c5784fbf7406d290bcdb7bd180a28238e0143200321727dcf55d0ad
|
|
| MD5 |
8a55e8a6d170b1a54125e9ac353e46f3
|
|
| BLAKE2b-256 |
0a6458effa534b3a302980c0dde510f7e02f98da979fbd7cc603afa04dda96ae
|