alexei_led_aws_mcp_server

alexei_led_aws_mcp_server

by alexei-led
Enables AI assistants like Claude to execute AWS CLI commands safely through the Model Context Protocol (MCP).

AWS CLI Integration for AI Assistants via MCP

Overview

The AWS MCP Server bridges MCP-aware AI assistants (like Claude Desktop, Cursor, and Windsurf) with the AWS CLI. It enables these assistants to:

  1. Retrieve AWS CLI documentation - Get detailed help on AWS services and commands.
  2. Execute AWS CLI commands - Run commands and receive formatted results optimized for AI consumption.
flowchart LR
    AI[AI Assistant] <-->|MCP Protocol| Server[AWS MCP Server]
    Server <-->|Subprocess| AWS[AWS CLI]
    AWS <-->|API| Cloud[AWS Cloud]

Demo

Watch the demo video demonstrating the use of Claude Desktop with AWS MCP Server to create a new AWS EC2 instance with AWS SSM agent installed.

Features

  • Command Documentation - Detailed help information for AWS CLI commands.
  • Command Execution - Execute AWS CLI commands and return human-readable results.
  • Unix Pipe Support - Filter and transform AWS CLI output using standard Unix pipes and utilities.
  • Prompt Templates - Pre-defined prompt templates for common AWS tasks following best practices.
  • Docker Integration - Simple deployment through containerization with multi-architecture support (AMD64/x86_64 and ARM64).
  • AWS Authentication - Leverages existing AWS credentials on the host machine.

Requirements

  • Docker (default) or Python 3.13+ (and AWS CLI installed locally).
  • AWS credentials configured.

Getting Started

Option 1: Using Docker (Recommended)

# Clone repository
git clone https://github.com/alexei-led/aws-mcp-server.git
cd aws-mcp-server

# Build and run Docker container
docker compose -f deploy/docker/docker-compose.yml up -d

The Docker image supports both AMD64/x86_64 (Intel/AMD) and ARM64 (Apple Silicon M1-M4, AWS Graviton) architectures.

Note: The official image from GitHub Packages is multi-architecture and will automatically use the appropriate version for your system.

```shell

Use the latest stable version

docker pull ghcr.io/alexei-led/aws-mcp-server:latest

Or pin to a specific version (recommended for production)

docker pull ghcr.io/alexei-led/aws-mcp-server:1.0.0
```

Option 2: Using Python

# Clone repository
git clone https://github.com/alexei-led/aws-mcp-server.git
cd aws-mcp-server

# Set up virtual environment
python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate

# Install in development mode
pip install -e .

# Run the server
python -m aws_mcp_server

Configuration

The AWS MCP Server can be configured using environment variables:

Environment Variable Description Default
AWS_MCP_TIMEOUT Command execution timeout in seconds 300
AWS_MCP_MAX_OUTPUT Maximum output size in characters 100000
AWS_MCP_TRANSPORT Transport protocol to use ("stdio" or "sse") stdio
AWS_PROFILE AWS profile to use default
AWS_REGION AWS region to use us-east-1

Integrating with Claude Desktop

To integrate AWS MCP Server with Claude Desktop, follow these steps:

  1. Locate the Claude Desktop configuration file:
  2. macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  3. Windows: %APPDATA%\Claude\claude_desktop_config.json

  4. Edit the configuration file to include the AWS MCP Server:

{
  "mcpServers": {
    "aws-mcp-server": {
      "command": "docker",
      "args": [
        "run",
        "-i",
        "--rm",
        "-v",
        "/Users/YOUR_USER_NAME/.aws:/home/appuser/.aws:ro",
        "ghcr.io/alexei-led/aws-mcp-server:latest"
      ]
    }
  }
}
  1. Restart Claude Desktop to apply the changes.
flowchart TD
    subgraph "User Device"
        config[Edit claude_desktop_config.json]
        claude[Claude Desktop]
        docker[Docker Container]
        aws_creds[AWS Credentials]
    end

    subgraph "AWS Cloud"
        services[AWS Services]
    end

    config -->|Add MCP Server Config| claude
    claude -->|Docker Run Command| docker
    aws_creds -->|Mount Read-only| docker
    docker -->|API Calls| services

Example Interactions

Getting AWS CLI Documentation:

User: What are the available options for the AWS S3 cp command?

Claude: Let me get that information for you.

The AWS S3 cp command has the following options:

NAME
    cp - Copies a local file or S3 object to another location locally or in S3.

SYNOPSIS
    cp <LocalPath> <S3Uri> or <S3Uri> <LocalPath> or <S3Uri> <S3Uri> [--acl <value>] [--cache-control <value>] ...

Executing AWS CLI Commands:

User: List my S3 buckets

Claude: I'll list your S3 buckets for you.

2023-10-15 14:30:45 my-bucket-1
2023-11-20 09:15:32 my-bucket-2
2024-01-05 11:22:18 my-backup-bucket

Using Command Pipes:

User: List my S3 buckets that have "backup" in their name and show them in alphabetical order

Claude: Let me find that for you.

2024-01-05 11:22:18 my-backup-bucket
2024-03-01 09:44:12 weekly-backup-bucket
2024-03-15 13:10:57 database-backup-bucket

Using Prompt Templates:

User: I need to perform a security audit of my S3 buckets

Claude: I'll help you audit the security of your S3 buckets.

Here are AWS CLI commands to perform a comprehensive security audit:

# List all buckets with public access settings
aws s3api list-buckets --query 'Buckets[*].Name' --output text | xargs -I {} aws s3api get-public-access-block --bucket {}

# Check bucket policies for public access
aws s3api list-buckets --query 'Buckets[*].Name' --output text | xargs -I {} aws s3api get-bucket-policy --bucket {} 2>/dev/null

# Identify buckets without encryption
aws s3api list-buckets --query 'Buckets[*].Name' --output text | xargs -I {} aws s3api get-bucket-encryption --bucket {} 2>/dev/null

# Check for buckets without logging enabled
aws s3api list-buckets --query 'Buckets[*].Name' --output text | xargs -I {} aws s3api get-bucket-logging --bucket {} 2>/dev/null

# Verify bucket versioning status
aws s3api list-buckets --query 'Buckets[*].Name' --output text | xargs -I {} aws s3api get-bucket-versioning --bucket {}

Available Prompt Templates

Prompt Description Parameters
create_resource Generate commands to create AWS resources with best practices resource_type, resource_name
security_audit Audit security settings for a specific AWS service service
cost_optimization Find cost optimization opportunities for a service service
resource_inventory Create comprehensive inventory of resources service, region (optional)
troubleshoot_service Generate commands to troubleshoot service issues service, resource_id
iam_policy_generator Create least-privilege IAM policies service, actions, resource_pattern (optional)
service_monitoring Set up comprehensive monitoring service, metric_type (optional)
disaster_recovery Implement disaster recovery solutions service, recovery_point_objective (optional)
compliance_check Check compliance with standards compliance_standard, service (optional)
resource_cleanup Identify and safely clean up resources service, criteria (optional)

Security

  • The server uses AWS credentials from the host machine.
  • All commands are validated before execution.
  • Timeout limits prevent long-running commands.
  • Commands must start with the 'aws' prefix.
  • Potentially dangerous commands are restricted.

Development

Setting Up the Development Environment

# Install only runtime dependencies
pip install -e .

# Install all development dependencies
pip install -e ".[dev]"

# Run unit tests
pytest -k "not integration"

# Run tests with coverage report
pytest -k "not integration" --cov-report=html

# Run linting
ruff check src/ tests/

# Run formatting
ruff format src/ tests/

Code Coverage

The project includes configuration for Codecov to track code coverage metrics. The configuration is in the codecov.yml file, which:

  • Sets a target coverage threshold of 80%.
  • Excludes test files, setup files, and documentation from coverage reports.
  • Configures PR comments and status checks.

Integration Testing

Integration tests verify AWS MCP Server works correctly with actual AWS resources. To run them:

  1. Set up AWS resources:
  2. Create an S3 bucket for testing.
  3. Set the environment variable: export AWS_TEST_BUCKET=your-test-bucket-name.
  4. Ensure your AWS credentials are configured.

  5. Run integration tests:

# Run all tests including integration tests
pytest --run-integration

# Run only integration tests
pytest --run-integration -m integration

Troubleshooting

  • Authentication Issues: Ensure your AWS credentials are properly configured.
  • Connection Errors: Verify the server is running and AI assistant connection settings are correct.
  • Permission Errors: Check that your AWS credentials have the necessary permissions.
  • Timeout Errors: For long-running commands, increase the AWS_MCP_TIMEOUT environment variable.

Why Deploy with Docker

Security Benefits

  • Isolation: The Docker container provides complete isolation - AWS CLI commands and utilities run in a contained environment, not directly on your local machine.
  • Controlled Access: The container only has read-only access to your AWS credentials.
  • No Local Installation: Avoid installing AWS CLI and supporting tools directly on your host system.
  • Clean Environment: Each container run starts with a pristine, properly configured environment.

Reliability Advantages

  • Consistent Configuration: All required tools (AWS CLI, SSM plugin, jq) are pre-installed and properly configured.
  • Dependency Management: Avoid version conflicts between tools and dependencies.
  • Cross-Platform Consistency: Works the same way across different operating systems.
  • Complete Environment: Includes all necessary tools for command pipes, filtering, and formatting.

Other Benefits

  • Multi-Architecture Support: Runs on both Intel/AMD (x86_64) and ARM (Apple Silicon, AWS Graviton) processors.
  • Simple Updates: Update to new versions with a single pull command.
  • No Python Environment Conflicts: Avoids potential conflicts with other Python applications on your system.
  • Version Pinning: Easily pin to specific versions for stability in production environments.

License

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

About

A lightweight service that enables AI assistants to execute AWS CLI commands (in safe containerized environment) through the Model Context Protocol (MCP). Bridges Claude, Cursor, and other MCP-aware AI tools with AWS CLI for enhanced cloud infrastructure management.

Topics

Resources

License

Activity

Stars

Watchers

Forks

Releases

Packages

Languages

  • Python 94.1%
  • Dockerfile 3.9%
  • Shell 2.0%

Features & Capabilities

Categories
mcp_server model_context_protocol aws docker python claude api_integration cloud-infrastructure ai-assistant

Implementation Details

Stats

0 Views
17 GitHub Stars

Repository Info

alexei-led Organization

Similar MCP Servers

continuedev_continue by continuedev
25049
21423
9300