A comprehensive Model Context Protocol (MCP) server for managing cPanel web hosting accounts. This server provides tools to interact with cPanel's UAPI (Unified API) for common hosting management tasks, enabling seamless integration with AI assistants and automation workflows.
- File Management: Browse, list, and manage files through cPanel's File Manager
- Database Operations: Create, delete, and list MySQL databases
- Email Management: Manage email accounts with full CRUD operations
- Domain Information: Retrieve domain and subdomain details
- Cron Job Management: Schedule and manage automated tasks
- System Monitoring: Monitor disk usage and account statistics
- Backup Operations: Create and manage account backups
- Secure Authentication: Support for both API tokens and password authentication
- Node.js 18.0.0 or higher
- A cPanel hosting account with API access
- Either a cPanel password or API token for authentication
git clone https://github.com/ringo380/cpanel-mcp.git
cd cpanel-mcp
npm install
npm run buildnpm install -g cpanel-mcp- Copy the example environment file:
cp .env.example .env- Configure your cPanel credentials in
.env:
# Required: cPanel server details
CPANEL_HOSTNAME=your-cpanel-hostname.com
CPANEL_USERNAME=your-cpanel-username
# Authentication (choose one method)
CPANEL_API_TOKEN=your-api-token-here
# OR
CPANEL_PASSWORD=your-cpanel-password
# Optional: Connection settings
CPANEL_PORT=2083
CPANEL_SSL=true- Log into your cPanel account
- Navigate to Security β Manage API Tokens
- Click Create Token
- Give it a descriptive name and set permissions
- Copy the generated token to your
.envfile
npm startThe server will start and listen for MCP connections via stdio.
Add the server to your Claude Desktop configuration:
{
"mcpServers": {
"cpanel": {
"command": "node",
"args": ["/path/to/cpanel-mcp/dist/index.js"],
"env": {
"CPANEL_HOSTNAME": "your-hostname.com",
"CPANEL_USERNAME": "your-username",
"CPANEL_API_TOKEN": "your-token"
}
}
}
}list_files- List files and directories in specified path{ "name": "list_files", "arguments": { "path": "/public_html" } }
list_databases- List all MySQL databasescreate_database- Create a new MySQL databasedelete_database- Delete an existing database
list_email_accounts- List all email accounts (optionally filter by domain)create_email_account- Create a new email accountdelete_email_account- Delete an email account
list_domains- List all domains and subdomains
list_cron_jobs- List all scheduled cron jobsadd_cron_job- Schedule a new cron jobdelete_cron_job- Remove a cron job
get_disk_usage- Get detailed disk usage statistics
create_backup- Create a full account backuplist_backups- List available backups
// Create a new database
await callTool("create_database", {
name: "myapp_db"
});
// Create an email account with 500MB quota
await callTool("create_email_account", {
email: "[email protected]",
password: "secure_password_123",
quota: 500
});// Add a daily backup cron job
await callTool("add_cron_job", {
minute: "0",
hour: "2",
day: "*",
month: "*",
weekday: "*",
command: "/usr/local/bin/backup_script.sh"
});- Use API Tokens: Prefer API tokens over passwords for better security
- Environment Variables: Never commit credentials to version control
- Limited Scope: The server only exposes safe, account-level operations
- HTTPS: Always use SSL/TLS connections to cPanel (enabled by default)
git clone https://github.com/ringo380/cpanel-mcp.git
cd cpanel-mcp
npm install
cp .env.example .env
# Edit .env with your test cPanel credentialsnpm run dev # Start in watch mode
npm run build # Build TypeScript to JavaScript
npm run lint # Run ESLint
npm run typecheck # Run TypeScript type checkingnpm test # Run test suite
npm run test:watch # Run tests in watch modeWe welcome contributions! Please see our Contributing Guidelines for details.
- Fork the repository
- Create a feature branch:
git checkout -b feature/amazing-feature - Make your changes and add tests
- Ensure tests pass:
npm test - Commit with conventional commits:
git commit -m "feat: add amazing feature" - Push to your fork and submit a pull request
- Fileman: File management operations
- Mysql: Database operations
- Email: Email account management
- DomainInfo: Domain information
- Cron: Cron job management
- StatsBar: Usage statistics
- Backup: Backup operations
For detailed cPanel UAPI documentation, visit: cPanel UAPI Documentation
Connection Failed
- Verify
CPANEL_HOSTNAMEis correct and accessible - Check that the specified port is open (default: 2083 for HTTPS)
- Ensure SSL setting matches your cPanel configuration
Authentication Failed
- Verify username and password/API token are correct
- Check that API access is enabled for your account
- Ensure API token has sufficient permissions
Tool Execution Errors
- Check cPanel error logs for detailed error messages
- Verify you have necessary permissions for the operation
- Ensure target resources (databases, emails, etc.) exist
Enable debug logging by setting:
DEBUG=cpanel-mcp:*This project is licensed under the MIT License - see the LICENSE file for details.
- Model Context Protocol by Anthropic
- cPanel UAPI documentation
- The open source community for inspiration and tools
- π Bug Reports: GitHub Issues
- π‘ Feature Requests: GitHub Discussions
- π Documentation: Wiki
Star β this repository if you find it helpful!