AWS CLI
Interact with AWS services using the AWS CLI. Requires AWS CLI to be installed and configured.
use_aws MCP Server
🌟 amazon-q-cli is great, and it is great because it has use_aws MCP tool to interact with AWS API.
💡 Wouldn't it be greater if this use_aws was portable, and use it across different AI tools, whichever you're currently using?
⚡ use_aws_mcp is a standalone Model Context Protocol (MCP) server that provides AWS CLI functionality through a standardized interface.
This server replicates the functionality of the use_aws tool from the Amazon Q Developer CLI.
🎬 Demo
-
Usage with Avante, MCPHub in nvim

-
Usage with Cursor

✨ Features
- AWS CLI Integration: Execute AWS CLI commands with proper parameter handling
- Safety Checks: Automatic detection of read-only vs. write operations
- User Agent Management: Proper AWS CLI user agent setup for tracking
- Parameter Formatting: Automatic conversion of parameters to kebab-case for CLI compatibility
- Error Handling: Comprehensive error handling and output formatting
- MCP Protocol: Full Model Context Protocol compliance
- Human-Readable Descriptions: Rich command descriptions using terminal formatting
📦 Installation
📋 Prerequisites
- 🦀 Rust (1.70 or later), Cargo
- for MacOS and linux, install with
curl https://sh.rustup.rs -sSf | sh
- for MacOS and linux, install with
- ☁️ AWS CLI installed and configured
- 🔑 AWS credentials configured (via AWS CLI, environment variables, or IAM roles)
🔨 Building
cargo build --release
The binary will be available at target/release/use_aws.
🚀 Usage
🔗 MCP Client Integration
To use this server with an MCP client, first install it using Cargo:
cargo install use_aws_mcp
Then configure your MCP client with:
{
"mcpServers": {
"use_aws_mcp": {
"name": "use_aws_mcp",
"command": "use_aws_mcp",
"timeout": 300,
"env": {},
"disabled": false
}
}
}
⚠️ Important Caveat for Using MCP Client
With q cli, mcp clients are shell process, so credentials env like AWS_DEFAULT_PROFILE are automatically transfered to mcp server.
However, non shell mcp clients like cursor cannot take advantage of this, so it is best advised to require mcp clients directly to use specific aws profile.
📋 User Flow:
- Set mcp.json above
- Set API key, or login to specific profile using
aws sso login - Ask away mcp client aws related questions! and be sure to require it to use specific profile.
Running the MCP Server Locally
./target/release/use_aws_mcp
The server communicates via stdin/stdout using JSON-RPC protocol.
Command Descriptions
The server provides human-readable descriptions of AWS CLI commands. You can see this in action by running the example:
cargo run --example description_demo
This will output something like:
Running aws cli command:
Service name: s3
Operation name: list-buckets
Parameters:
- max-items: "10"
- query: "Buckets[].Name"
Profile name: development
Region: us-west-2
Label: List S3 buckets with query
✅ This command is read-only (no acceptance required)
🛠️ Tool Specification
The server provides a single tool called use_aws with the following schema:
{
"name": "use_aws",
"description": "Execute AWS CLI commands with proper parameter handling and safety checks",
"inputSchema": {
"type": "object",
"properties": {
"service_name": {
"type": "string",
"description": "AWS service name (e.g., s3, ec2, lambda)"
},
"operation_name": {
"type": "string",
"description": "AWS CLI operation name (e.g., list-buckets, describe-instances)"
},
"parameters": {
"type": "object",
"description": "Optional parameters for the AWS CLI command",
"additionalProperties": true
},
"region": {
"type": "string",
"description": "AWS region (e.g., us-west-2, eu-west-1)"
},
"profile_name": {
"type": "string",
"description": "Optional AWS profile name"
},
"label": {
"type": "string",
"description": "Optional label for the operation"
}
},
"required": ["service_name", "operation_name", "region"]
}
}
📚 Examples
List S3 Buckets
{
"name": "use_aws",
"arguments": {
"service_name": "s3",
"operation_name": "ls",
"region": "us-west-2"
}
}
Describe EC2 Instances
{
"name": "use_aws",
"arguments": {
"service_name": "ec2",
"operation_name": "describe-instances",
"region": "us-west-2",
"parameters": {
"instance-ids": "i-1234567890abcdef0"
}
}
}
List Lambda Functions with Profile
{
"name": "use_aws",
"arguments": {
"service_name": "lambda",
"operation_name": "list-functions",
"region": "us-west-2",
"profile_name": "development"
}
}
🛡️ Safety Features
Read-Only Operation Detection
The server automatically detects read-only operations based on the operation name prefix:
- Read-only prefixes:
get,describe,list,ls,search,batch_get - Write operations: All other operations require explicit user acceptance
Output Truncation
Large outputs are automatically truncated to prevent memory issues, with a maximum response size of 100KB.
Development
Running Tests
cargo test
🔨 Building for Development
cargo build
Running with Logging
RUST_LOG=use_aws=debug cargo run
Examples
# Run the description demo
cargo run --example description_demo
Architecture
The project is structured as follows:
src/lib.rs: Core library with types and constantssrc/error.rs: Error handling typessrc/use_aws.rs: Core AWS CLI functionality (replicated from original)src/mcp_server.rs: MCP server implementationsrc/main.rs: Binary entry pointexamples/description_demo.rs: Example demonstrating command descriptions
📦 Dependencies
If you do not have Cargo (the Rust package manager) installed, you can get it by installing Rust using rustup:
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
Follow the on-screen instructions to complete the installation. After installation, restart your terminal and ensure Cargo is available by running:
cargo --version
You should see the installed Cargo version printed.
This project is distributed as a Rust crate. The following dependencies are managed automatically by Cargo:
tokioserdeserde_jsoneyrebstrconvert_caseasync-traitthiserrortracingtracing-subscribercrossterm
test/dev dependencies:
tokio-test
You do not need to install these manually; Cargo will handle them during installation.
📄 License
MIT, Apache-2.0
🤝 Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests
- Submit a pull request
🔒 Security
This server executes AWS CLI commands, which may have security implications:
- Ensure proper AWS credentials and permissions
- Review all commands before execution
- Use read-only operations when possible
- Consider running in a restricted environment
🔧 Troubleshooting
Common Issues
- AWS CLI not found: Ensure AWS CLI is installed and in PATH
- Permission denied: Check AWS credentials and permissions
- Invalid region: Verify the region name is correct
- Parameter errors: Check parameter names and values
Debug Mode
Run with debug logging to see detailed information:
RUST_LOG=use_aws=debug ./target/release/use_aws
References
관련 서버
Appwrite
Interact with the Appwrite API to manage your backend services.
Weather Alerts
Provides real-time weather alerts for US states using the National Weather Service API.
Skyvia MCP
Skyvia MCP Endpoint is a no-code gateway that makes your business data accessible to AI assistants in real time.
Minibridge
A backend-to-frontend bridge that securely exposes MCP servers to the internet, supporting agent authentication, content analysis, transformation, and telemetry.
AWS Cognito MCP Server
An MCP server for AWS Cognito, providing authentication and user management.
Dokploy
An AI-powered interface for managing the Dokploy infrastructure platform.
Vidu MCP
Access Vidu's latest video generation models via the Model Context Protocol (MCP).
AWS MCP Server
Execute AWS CLI commands through the Model Context Protocol (MCP). Requires AWS credentials configured on the host.
notebooklm-mcp-secure
Security-hardened NotebookLM MCP with post-quantum encryption, GDPR/SOC2 compliance, and 14 security layers. Query Google's Gemini-grounded research from any MCP-compatible AI assistant.
EnergyAtIt Grid MCP Server
EnergyAtIt is the first MCP server for physical grid infrastructure. 45 tools that let AI agents interact with power grid assets — translating 8 grid protocols (IEC 61850, DNP3, Modbus, OpenADR, OCPP, IEEE 2030.5) into MCP tool calls.