cpanel-mcp

cpanel-mcp

A comprehensive MCP server for managing cPanel web hosting accounts via UAPI, enabling file, database, email, domain, cron, backup, and system monitoring operations.

Category
Visit Server

README

cPanel MCP Server

MIT License TypeScript Node.js

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.

๐Ÿš€ Features

  • 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

๐Ÿ“‹ Prerequisites

  • Node.js 18.0.0 or higher
  • A cPanel hosting account with API access
  • Either a cPanel password or API token for authentication

๐Ÿ› ๏ธ Installation

Option 1: Clone and Build

git clone https://github.com/ringo380/cpanel-mcp.git
cd cpanel-mcp
npm install
npm run build

Option 2: Direct Installation

npm install -g cpanel-mcp

โš™๏ธ Configuration

Environment Setup

  1. Copy the example environment file:
cp .env.example .env
  1. 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

Generating a cPanel API Token (Recommended)

  1. Log into your cPanel account
  2. Navigate to Security โ†’ Manage API Tokens
  3. Click Create Token
  4. Give it a descriptive name and set permissions
  5. Copy the generated token to your .env file

๐Ÿš€ Usage

Starting the Server

npm start

The server will start and listen for MCP connections via stdio.

Integration with Claude Desktop

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"
      }
    }
  }
}

๐Ÿ› ๏ธ Available Tools

File Management

  • list_files - List files and directories in specified path
    {
      "name": "list_files",
      "arguments": {
        "path": "/public_html"
      }
    }
    

Database Management

  • list_databases - List all MySQL databases
  • create_database - Create a new MySQL database
  • delete_database - Delete an existing database

Email Management

  • list_email_accounts - List all email accounts (optionally filter by domain)
  • create_email_account - Create a new email account
  • delete_email_account - Delete an email account

Domain Operations

  • list_domains - List all domains and subdomains

Cron Job Management

  • list_cron_jobs - List all scheduled cron jobs
  • add_cron_job - Schedule a new cron job
  • delete_cron_job - Remove a cron job

System Information

  • get_disk_usage - Get detailed disk usage statistics

Backup Operations

  • create_backup - Create a full account backup
  • list_backups - List available backups

๐Ÿ’ก Examples

Creating a Database and Email Account

// Create a new database
await callTool("create_database", {
  name: "myapp_db"
});

// Create an email account with 500MB quota
await callTool("create_email_account", {
  email: "support@mydomain.com",
  password: "secure_password_123",
  quota: 500
});

Managing Cron Jobs

// 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"
});

๐Ÿ”’ Security Considerations

  • 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)

๐Ÿงช Development

Setup Development Environment

git clone https://github.com/ringo380/cpanel-mcp.git
cd cpanel-mcp
npm install
cp .env.example .env
# Edit .env with your test cPanel credentials

Development Commands

npm run dev        # Start in watch mode
npm run build      # Build TypeScript to JavaScript
npm run lint       # Run ESLint
npm run typecheck  # Run TypeScript type checking

Testing

npm test           # Run test suite
npm run test:watch # Run tests in watch mode

๐Ÿค Contributing

We welcome contributions! Please see our Contributing Guidelines for details.

Quick Start for Contributors

  1. Fork the repository
  2. Create a feature branch: git checkout -b feature/amazing-feature
  3. Make your changes and add tests
  4. Ensure tests pass: npm test
  5. Commit with conventional commits: git commit -m "feat: add amazing feature"
  6. Push to your fork and submit a pull request

๐Ÿ“š API Reference

cPanel UAPI Modules Used

  • 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

๐Ÿ› Troubleshooting

Common Issues

Connection Failed

  • Verify CPANEL_HOSTNAME is 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

Debug Mode

Enable debug logging by setting:

DEBUG=cpanel-mcp:*

๐Ÿ“„ License

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

๐Ÿ™ Acknowledgments

๐Ÿ“ž Support


Star โญ this repository if you find it helpful!

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured