cPanel MCP Server
A comprehensive MCP server for managing cPanel hosting accounts through AI assistants. It supports DNS, email (DKIM/SPF), databases, domains, SSL, PHP, cron jobs, security, Git deployment, and more.
README
cPanel MCP Server
A comprehensive Model Context Protocol (MCP) server for managing cPanel hosting accounts through AI assistants. Connects directly to cPanel's UAPI and API2, enabling natural language management of web hosting — DNS, DNSSEC, email (with DKIM/SPF), databases, domains, SSL/AutoSSL, PHP, cron jobs, security (WAF, IP blocker, virus scanner, 2FA), Git deployment, Node.js/Python apps, and more.
Features
File Management
- List, create, read, edit, and delete files in your hosting account
Disk Usage
- Account quota info — check disk space consumption and limits
MySQL Database Management
- Full CRUD for databases, users, and privileges
- Server info — version and restriction details
- Privilege management — grant/revoke per database
PostgreSQL Database Management
- Full CRUD for databases, users, and privileges
- Grant/revoke access per database
Email Management
- Email accounts — create, delete, change password, set quotas, list with disk usage
- Forwarders — create, list, and delete email forwarding rules
- Autoresponders — create, list, and delete out-of-office / autoresponse messages
- Email routing — view mail domain configuration
Email Authentication (DKIM/SPF)
- DKIM — enable, disable, validate, and ensure keys exist for all domains
- SPF — validate and install/update SPF records
- PTR — validate reverse DNS records
Email Filters & Spam
- Email filters — list, delete, and trace/test filters
- SpamAssassin — enable/disable, configure spam box, get settings, clear spam
- Greylisting — enable/disable for all domains
DNS Management
- Get zone records for any domain (via API2 ZoneEdit)
- Add, edit, and delete DNS records (A, AAAA, CNAME, MX, TXT, SRV, CAA)
DNSSEC
- Enable/disable DNSSEC for domains
- DS records — fetch for registrar configuration
- DNSKEY export — export zone keys
- NSEC3 — enable/disable (prevents zone enumeration)
Domain Management
- List all domains — main, addon, subdomains, and parked
- Addon domains — create and delete
- Subdomains — create and delete with custom document roots
- Parked domains (aliases) — park and unpark
- Redirects — create and delete URL redirects (301/302)
Cron Job Management
- List, create, edit, and delete cron jobs (via API2)
- Notification email — get and set the cron notification address
PHP Management
- List installed PHP versions available on the server
- Get/set PHP version per domain
- PHP INI directives — read and modify (memory_limit, upload_max_filesize, etc.)
SSL/TLS Management
- List certificates and SSL status per domain
- Install and delete SSL certificates
- Generate CSR for certificate requests
- AutoSSL — check status and trigger renewal
- List private keys
Security
- IP Blocker — list, block, and unblock IP addresses/ranges
- SSH Keys — list, import, delete, authorize, and deauthorize keys
- Hotlink Protection — get status, enable with custom settings, disable
- Directory Privacy — list protected directories and add users
ModSecurity (WAF)
- Status — check if ModSecurity is installed, list domain status
- Enable/disable globally or per domain
Two-Factor Authentication
- Status — check if 2FA is configured
- Setup — generate secret/QR code, enable with verification
- Remove — disable 2FA
Virus Scanner (ClamAV) requires ClamAV plugin
- Scan — start virus scan on a directory
- Status — check scan progress
- Results — list infected files, quarantine/disinfect
Metrics & Logs
- Bandwidth usage statistics
- Resource usage — CPU, memory, I/O, entry processes
- Error logs — recent error entries
- Visitor stats — per-domain access statistics
- Account stats — summary of email accounts, databases, domains, disk, bandwidth
Backup Management
- Full account backup to home directory
- Partial backups — home directory, databases, and email separately
- Restore — database and file restore from backup
- List available backups
FTP Management
- List FTP accounts with disk usage
- Create and delete FTP accounts
- Change password and quota
- Active sessions — list and terminate
- Server port info
Applications & Deployment
- WordPress — list installations (requires WP Toolkit / Instance Manager)
- Node.js/Python/Ruby apps — register, unregister, enable, disable, install dependencies (requires Phusion Passenger)
- Git repositories — create, list, update, delete, and deploy via
.cpanel.yml(requires Git Version Control feature)
Account Management
- API tokens — list, create, rename, and revoke
- Features — list available features, check if specific features are enabled
- Account info — user information, server details
Installation and Configuration
Prerequisites
- Node.js 18+
- A cPanel account with API token access
Build
npm install
npm run build
Configure
Add the following to your MCP settings configuration (e.g., claude_desktop_config.json, cline_mcp_settings.json, or your IDE's MCP config):
{
"mcpServers": {
"cpanel": {
"command": "node",
"args": ["/path/to/cPanel-MCP-Server/build/index.js"],
"env": {
"CPANEL_USERNAME": "your_cpanel_username",
"CPANEL_API_TOKEN": "your_cpanel_api_token",
"CPANEL_SERVER_URL": "https://your-domain.com:2083"
}
}
}
}
Replace the placeholder values with your actual cPanel credentials.
Environment Variables
| Variable | Required | Default | Description |
|---|---|---|---|
CPANEL_USERNAME |
Yes | — | cPanel account username |
CPANEL_API_TOKEN |
Yes | — | API token for authentication |
CPANEL_SERVER_URL |
Yes | — | cPanel server URL (e.g., https://example.com:2083) |
CPANEL_TIMEOUT_MS |
No | 30000 |
Request timeout in milliseconds |
CPANEL_VERIFY_SSL |
No | true |
Set to false to disable SSL certificate verification (for self-signed certs) |
Getting a cPanel API Token
- Log in to cPanel
- Go to Security > Manage API Tokens
- Create a new token with a descriptive name
- Copy the token — it won't be shown again
Available Tools (164 total)
| Category | Count |
|---|---|
| File Management | 5 |
| Disk Usage | 1 |
| MySQL | 9 |
| PostgreSQL | 8 |
| Email (accounts, forwarders, autoresponders) | 12 |
| Email Authentication (DKIM/SPF/PTR) | 7 |
| Email Filters & Spam | 12 |
| DNS | 4 |
| DNSSEC | 6 |
| Domains (addon, sub, parked, redirects) | 14 |
| Cron Jobs | 6 |
| PHP | 5 |
| SSL/TLS & AutoSSL | 8 |
| Security (IP blocker, SSH, hotlink, privacy) | 13 |
| ModSecurity (WAF) | 5 |
| Two-Factor Auth | 4 |
| Virus Scanner (ClamAV) | 4 |
| Metrics & Logs | 5 |
| Backups | 7 |
| FTP | 8 |
| WordPress | 1 |
| Passenger Apps (Node.js/Python/Ruby) | 6 |
| Git Version Control & Deployment | 6 |
| API Tokens | 4 |
| Account & Server Info | 4 |
Architecture
src/
├── index.ts # MCP server entry point — registers all 25 tool modules
├── cpanel-api.ts # cPanel API client (UAPI + API2, token auth, error handling)
└── tools/
├── files.ts # File operations (Fileman)
├── disk.ts # Disk usage (Quota, DiskUsage)
├── mysql.ts # MySQL databases (Mysql)
├── postgresql.ts # PostgreSQL databases (Postgresql)
├── email.ts # Email accounts, forwarders, autoresponders (Email)
├── email-auth.ts # DKIM, SPF, PTR validation (EmailAuth)
├── email-filters.ts # Filters, SpamAssassin, Greylisting
├── dns.ts # DNS zone records (DNS)
├── dnssec.ts # DNSSEC management (DNSSEC)
├── domains.ts # Domains, subdomains, redirects
├── cron.ts # Cron jobs (API2 Cron)
├── php.ts # PHP version & INI (LangPHP)
├── ssl.ts # SSL/TLS & AutoSSL (SSL)
├── security.ts # IP blocker, SSH, hotlink, privacy
├── modsecurity.ts # ModSecurity WAF
├── twofa.ts # Two-factor authentication
├── virus-scanner.ts # ClamAV virus scanner
├── metrics.ts # Bandwidth, resources, logs, stats
├── backups.ts # Full & partial backups, restore
├── ftp.ts # FTP accounts & sessions
├── wordpress.ts # WordPress installations
├── passenger.ts # Node.js/Python/Ruby apps
├── version-control.ts # Git repos & deployment
├── tokens.ts # API token management
└── features.ts # Feature checks & server info
API Compatibility
- UAPI (preferred) — used for most modules
- API2 (legacy) — used where cPanel has no UAPI equivalent:
- Cron jobs —
Cron::fetchcron,add_line,edit_line,remove_line,get_email,set_email - DNS records —
ZoneEdit::fetchzone_records,add_zone_record,edit_zone_record,remove_zone_record - Subdomains —
SubDomain::listsubdomains,addsubdomain,delsubdomain - Addon domains —
AddonDomain::listaddondomains,addaddondomain,deladdondomain - Parked domains —
Park::listparkeddomains,park,unpark - IP blocking list —
DenyIp::listdenyips
- Cron jobs —
- Both API versions share the same authenticated client with retry logic and error handling
Security
Your cPanel credentials are loaded from environment variables at runtime and are never stored in the repository. The API token should be treated as a secret — do not commit it to version control.
License
ISC
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.