Skip to main content

Model Context Protocol (MCP) server for AWS - comprehensive AWS CLI wrapper

Project description

AWS MCP Server

A Python Model Context Protocol (MCP) server that lets MCP-compatible clients inspect and operate AWS through the AWS CLI. It supports command execution with validation, command suggestions, AWS region lookup, and caller identity checks.

Features

  • Execute AWS CLI commands without shell expansion, preserving quoted arguments with shell-style parsing
  • Suggest common AWS CLI commands from natural language requests
  • Return available AWS regions
  • Return the current caller identity
  • Support stdio transport for local MCP clients
  • Validate configuration and write logs to stderr plus a local log file

Safety Model

This server can execute AWS CLI commands using the credentials available to the process. It blocks shell operators by using subprocess.run(..., shell=False) and flags destructive-looking commands, but it cannot replace IAM least privilege or human review. Use scoped AWS profiles or roles, prefer non-production accounts for testing, and keep destructive commands on manual approval in your MCP client.

Requirements

Installation

When published to PyPI, install or run the server like a standard Python MCP package:

uvx mdev-aws-mcp-server

For local development from source:

git clone https://github.com/musaddiq-dev/aws-cli-mcp-server.git
cd aws-cli-mcp-server
python -m venv .venv
source .venv/bin/activate
pip install -e .

Configuration

Before running this server, install the AWS CLI using the official AWS CLI install guide, then configure credentials using the official AWS CLI sign-in guide and AWS CLI configuration guide. AWS recommends short-term credentials where possible; avoid long-term IAM user keys unless your use case requires them.

Copy the example environment file and adjust values as needed.

cp .env.example .env
Variable Description Default
AWS_REGION Default AWS region us-east-1
AWS_PROFILE AWS credentials profile default
AWS_MCP_WORKING_DIR Working directory for file operations /tmp/aws-mcp-work
AWS_MCP_REQUIRE_CONFIRMATION Emit warnings for destructive-looking operations true
AWS_MCP_LOG_LEVEL Application log level INFO

Running

mdev-aws-mcp-server

From a local checkout before PyPI publication, run:

python -m aws_mcp_server.server

MCP Client Configuration

For published installs, prefer uvx. MCP servers using stdio must write protocol messages only to stdout; this server writes logs to stderr and a local file under ~/.aws-mcp-server/logs.

Claude Desktop / Cursor / Windsurf / Cline

Most MCP clients accept this mcpServers JSON shape:

{
  "mcpServers": {
    "aws": {
      "command": "uvx",
      "args": ["mdev-aws-mcp-server"],
      "env": {
        "AWS_PROFILE": "default",
        "AWS_REGION": "us-east-1"
      }
    }
  }
}

For local development from this repository, use the installed console script path instead:

{
  "mcpServers": {
    "aws": {
      "command": "/absolute/path/to/aws-cli-mcp-server/.venv/bin/mdev-aws-mcp-server",
      "args": [],
      "env": {
        "AWS_PROFILE": "default",
        "AWS_REGION": "us-east-1"
      }
    }
  }
}

Claude Code CLI

claude mcp add aws --env AWS_PROFILE=default --env AWS_REGION=us-east-1 -- uvx mdev-aws-mcp-server

VS Code MCP

VS Code uses the same command/args/env model in its MCP configuration:

{
  "servers": {
    "aws": {
      "type": "stdio",
      "command": "uvx",
      "args": ["mdev-aws-mcp-server"],
      "env": {
        "AWS_PROFILE": "default",
        "AWS_REGION": "us-east-1"
      }
    }
  }
}

Tools

Tool Purpose Safety
call_aws Execute an AWS CLI command Can modify AWS resources
suggest_aws_commands Suggest common AWS CLI commands Read-only
get_aws_regions List AWS regions Read-only
get_caller_identity Return current AWS identity Read-only

Development

pip install -e .
pip install -e '.[dev]'
pytest
ruff check .
ruff format .
pyright

Smoke Check

python -m py_compile src/aws_mcp_server/server.py src/aws_mcp_server/config.py src/aws_mcp_server/aws/executor.py
python -m pytest

Manual AWS check, if credentials are configured:

aws sts get-caller-identity

Distribution

This repository is prepared for the common Python MCP distribution path: publish the package to PyPI, keep the mcp-name marker at the top of this README for MCP Registry ownership verification, and publish server.json metadata with the GitHub repository. After release, users should prefer uvx mdev-aws-mcp-server in local MCP client configurations.

Security Notes

  • Do not commit .env, AWS credentials, profiles, access keys, or account-specific outputs.
  • Use least-privilege IAM permissions for the profile or role running this server.
  • Keep call_aws on explicit manual approval in your MCP client.
  • Do not expose this server over a network without adding authentication, TLS, and network controls.
  • Review generated command suggestions before executing them.

License

MIT

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

mdev_aws_mcp_server-0.1.1.tar.gz (12.5 kB view details)

Uploaded Source

Built Distribution

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

mdev_aws_mcp_server-0.1.1-py3-none-any.whl (11.8 kB view details)

Uploaded Python 3

File details

Details for the file mdev_aws_mcp_server-0.1.1.tar.gz.

File metadata

  • Download URL: mdev_aws_mcp_server-0.1.1.tar.gz
  • Upload date:
  • Size: 12.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mdev_aws_mcp_server-0.1.1.tar.gz
Algorithm Hash digest
SHA256 92119bac05437c772675ae9bd50bacc334cd9b4dbbf696f16a161a1a41ae6838
MD5 e065111cc5f624632f14b0110b4b3851
BLAKE2b-256 f5630081818ce29cad1c53aef5c1d8e9814d6c025e8581e1c3499fd8dbcf6d85

See more details on using hashes here.

Provenance

The following attestation bundles were made for mdev_aws_mcp_server-0.1.1.tar.gz:

Publisher: publish-pypi.yml on musaddiq-dev/aws-cli-mcp-server

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mdev_aws_mcp_server-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for mdev_aws_mcp_server-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e8737b1bf13d97bdd5920e0f553f48b0f394d32b56468bd5bb6164678ac142f9
MD5 38f319f200a0e071ea6ffedb0cf35ced
BLAKE2b-256 ddfdd57f83724449ed28b106959e05cf0b5d0f0748ac3ee7095c4191b687ae92

See more details on using hashes here.

Provenance

The following attestation bundles were made for mdev_aws_mcp_server-0.1.1-py3-none-any.whl:

Publisher: publish-pypi.yml on musaddiq-dev/aws-cli-mcp-server

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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