Skip to main content

Model Context Protocol server for CAST.AI - manage Kubernetes clusters via natural language

Project description

CAST.AI MCP Server

Model Context Protocol (MCP) server for the CAST.AI API. This server enables Claude Desktop and other MCP clients to interact with your CAST.AI Kubernetes clusters through natural language.

Features

  • 5 Cluster Management Tools:

    • list_clusters - List all your Kubernetes clusters
    • get_cluster_details - Get detailed information about a specific cluster
    • get_cluster_policies - View cluster policies and configuration
    • get_cluster_score - Get cluster optimization score
    • get_cluster_score_history - View historical cluster score data
  • Simple Authentication: API key-based authentication (no OAuth complexity)

  • Local Only: Works with Claude Desktop via stdio transport

  • Cluster Name Resolution: Use either cluster UUID or friendly cluster name

Prerequisites

  • For npx installation (recommended): Node.js 16+ and uv
  • For uvx installation: uv only
  • For local development: Python 3.11+ and uv
  • Always required: CAST.AI account with API access

Installation

Quick Start (Recommended) ⭐

The easiest way to use CAST.AI MCP Server - no installation or cloning required!

1. Get your CAST.AI API key:

  • Visit console.cast.ai
  • Navigate to Settings > API Keys
  • Click Create API Key
  • Choose Read-only access (recommended) or Full access
  • Copy the generated API key

2. Configure Claude Desktop:

Edit your Claude Desktop configuration file:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json

Add this configuration:

{
  "mcpServers": {
    "castai": {
      "command": "npx",
      "args": ["-y", "castai-mcp-server@latest"],
      "env": {
        "CASTAI_API_KEY": "your-api-key-here"
      }
    }
  }
}

3. Restart Claude Desktop

That's it! The server will be automatically downloaded and run when needed.


Alternative Installation Methods

Using uvx (Python package manager)

Requires: uv installed

{
  "mcpServers": {
    "castai": {
      "command": "uvx",
      "args": ["castai-mcp-server"],
      "env": {
        "CASTAI_API_KEY": "your-api-key-here"
      }
    }
  }
}

Restart Claude Desktop.

Development / Local Installation

For local development or if you want to modify the code:

  1. Clone the repository:
cd ~/repos
git clone https://github.com/castai/castai-mcp-external.git
cd castai-mcp-external
  1. Install dependencies:
uv sync
  1. Configure Claude Desktop:
{
  "mcpServers": {
    "castai": {
      "command": "uv",
      "args": [
        "--directory",
        "/ABSOLUTE/PATH/TO/castai-mcp-external",
        "run",
        "python",
        "main.py"
      ],
      "env": {
        "CASTAI_API_KEY": "your-api-key-here"
      }
    }
  }
}

Important: Replace /ABSOLUTE/PATH/TO/castai-mcp-external with the actual absolute path.

  1. Restart Claude Desktop

Usage Examples

Once configured, you can interact with your CAST.AI clusters using natural language in Claude Desktop:

List all clusters

Show me all my Kubernetes clusters

Get cluster details

Get details for cluster "production-gke"

or

Show me information about cluster a1b2c3d4-e5f6-7890-abcd-ef1234567890

View cluster policies

What are the policies configured for my staging cluster?

Check cluster optimization score

What's the optimization score for my production cluster?

View score history

Show me the historical cluster score for my main cluster

Configuration

Environment Variables

  • CASTAI_API_KEY (required) - Your CAST.AI API key from console.cast.ai
  • CASTAI_API_URL (optional) - API endpoint URL (defaults to https://api.cast.ai)

Using a Different API Endpoint

If you're using a non-production CAST.AI environment, you can override the API URL:

{
  "mcpServers": {
    "castai": {
      "command": "uv",
      "args": ["--directory", "/path/to/castai-mcp-external", "run", "python", "main.py"],
      "env": {
        "CASTAI_API_KEY": "your-api-key-here",
        "CASTAI_API_URL": "https://api.dev-master.cast.ai"
      }
    }
  }
}

Troubleshooting

Authentication Errors

If you see a 401 authentication error:

  1. Verify your API key is correct in claude_desktop_config.json
  2. Check that the API key hasn't expired in the CAST.AI console
  3. Ensure the API key has the necessary permissions
  4. Restart Claude Desktop after making changes

Cluster Not Found

If you get a "Cluster not found" error:

  • Verify you're using the exact cluster name as shown in CAST.AI console
  • Alternatively, use the cluster UUID instead of the name
  • Check that your API key has access to the cluster's organization

Server Not Starting

If the MCP server doesn't appear in Claude Desktop:

  1. Check the Claude Desktop logs:
    • macOS: ~/Library/Logs/Claude/mcp*.log
    • Windows: %APPDATA%\Claude\Logs\mcp*.log
  2. Verify the absolute path to castai-mcp-external is correct
  3. Ensure uv is installed and in your PATH
  4. Test the server manually:
    cd /path/to/castai-mcp-external
    export CASTAI_API_KEY="your-key"
    uv run python main.py
    

View Server Logs

To see detailed logs from the MCP server:

cd /path/to/castai-mcp-external
export CASTAI_API_KEY="your-key"
uv run python main.py

The server will output structured logs in logfmt format to stderr.

Security Best Practices

  1. Use Read-Only API Keys: For safety, create API keys with read-only access unless you specifically need write permissions
  2. Rotate API Keys Regularly: Periodically generate new API keys and update your configuration
  3. Protect Your API Key: Never commit API keys to version control or share them publicly
  4. Use Environment Variables: Always configure API keys via environment variables, not hardcoded in files

API Endpoints Used

This MCP server uses the following CAST.AI API endpoints:

  • GET /v1/kubernetes/external-clusters - List clusters
  • GET /v1/kubernetes/external-clusters/{id} - Get cluster details
  • GET /v1/kubernetes/clusters/{id}/policies - Get cluster policies
  • GET /v1/cost-reports/clusters/{id}/cluster-score - Get cluster score
  • GET /v1/cost-reports/clusters/{id}/cluster-score-history - Get score history

Documentation

Support

For issues or questions:

License

MIT License - see LICENSE file for details.

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

castai_mcp_server-0.2.1.tar.gz (89.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

castai_mcp_server-0.2.1-py3-none-any.whl (11.0 kB view details)

Uploaded Python 3

File details

Details for the file castai_mcp_server-0.2.1.tar.gz.

File metadata

  • Download URL: castai_mcp_server-0.2.1.tar.gz
  • Upload date:
  • Size: 89.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.5

File hashes

Hashes for castai_mcp_server-0.2.1.tar.gz
Algorithm Hash digest
SHA256 df836e130fee7c7ad3d001a6efe7285fcfe1eb31b482488d3126f525b828ff27
MD5 8004e6241f00ed85c39d0404a3d2ce05
BLAKE2b-256 6510f8c22e15c36542fcef3a39f3237471a0623e6aacdc1a6af14c52f67d530d

See more details on using hashes here.

File details

Details for the file castai_mcp_server-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for castai_mcp_server-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4475f3cdf7b2fc7cd409cdf0ca52a3908aeec48a585ebb63b877357890881a8e
MD5 9603df693d4d195beb8e22825e7345d1
BLAKE2b-256 e7cfc1a5c1a6c0772b50d8adfad990af025a4696de3ec6ed9a4fab812a89ab6b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page