AWS S3 MCP Server
An MCP server for managing files and buckets on AWS S3. Requires AWS credentials for authentication.
AWS S3 MCP Server
A Model Context Protocol (MCP) server for AWS S3 operations
Features
This MCP server provides tools for interacting with AWS S3:
Bucket Operations
list_buckets- List all S3 buckets in the AWS accountcreate_bucket- Create a new S3 bucketdelete_bucket- Delete an S3 bucket (must be empty)
Object Operations
list_objects- List objects in a bucket with optional prefix filteringupload_object- Upload a file or content to a bucketdownload_object- Download an object from a bucketdelete_object- Delete an object from a bucket
Policy Operations
get_bucket_policy- Get the policy attached to a bucketset_bucket_policy- Set or update a bucket policy
MCP Configuration
Create a configuration file for the MCP server:
{
"mcpServers": {
"aws-s3": {
"command": "npx",
"args": ["aws-s3"],
"env": {
"AWS_REGION": "us-east-1",
"AWS_ACCESS_KEY_ID": "your-access-key-id",
"AWS_SECRET_ACCESS_KEY": "your-secret-access-key"
},
"autoApprove": ["list_buckets", "list_objects", "get_bucket_policy"]
}
}
}
Available Tools
The MCP server provides the following tools:
| Tool Name | Description | Parameters |
|---|---|---|
list_buckets | Lists all S3 buckets in the AWS account | None |
create_bucket | Creates a new S3 bucket | bucketName (required), region (optional) |
delete_bucket | Deletes an empty S3 bucket | bucketName (required) |
list_objects | Lists objects in a bucket | bucketName (required), prefix, maxKeys, continuationToken (all optional) |
upload_object | Uploads a file or content to a bucket | bucketName, key (both required), filePath, content, contentType (all optional) |
download_object | Downloads an object from a bucket | bucketName, key (both required), outputPath, returnContent (both optional) |
delete_object | Deletes an object from a bucket | bucketName, key (both required) |
get_bucket_policy | Gets the policy for a bucket | bucketName (required) |
set_bucket_policy | Sets or updates a bucket policy | bucketName, policy (both required) |
AWS Authentication
The MCP server uses the AWS SDK, which looks for credentials in the following order:
- Environment variables (
AWS_ACCESS_KEY_IDandAWS_SECRET_ACCESS_KEY) - Shared credentials file (
~/.aws/credentials) - If running on Amazon EC2, EC2 instance metadata service
For local development, you can:
- Set environment variables in your MCP server configuration
- Configure the AWS CLI with
aws configure - Use AWS IAM roles if running in an AWS environment
Tool Documentation
list_buckets
Lists all S3 buckets in the AWS account.
Parameters: None
Response:
{
"success": true,
"buckets": [
{
"name": "my-bucket",
"creationDate": "2023-01-15T00:00:00.000Z"
}
],
"count": 1
}
create_bucket
Creates a new S3 bucket with the specified name.
Parameters:
bucketName(string, required): Name of the bucket to createregion(string, optional): AWS region where the bucket should be created
Response:
{
"success": true,
"bucketName": "my-new-bucket",
"location": "http://my-new-bucket.s3.amazonaws.com/"
}
delete_bucket
Deletes an S3 bucket. The bucket must be empty.
Parameters:
bucketName(string, required): Name of the bucket to delete
Response:
{
"success": true,
"bucketName": "my-bucket"
}
list_objects
Lists objects in an S3 bucket with optional prefix filtering.
Parameters:
bucketName(string, required): Name of the bucket to list objects fromprefix(string, optional): Filter objects by prefix (folder path)maxKeys(number, optional): Maximum number of objects to return (default: 1000)continuationToken(string, optional): Token to retrieve the next set of results
Response:
{
"success": true,
"objects": [
{
"key": "folder/file.txt",
"size": 1024,
"lastModified": "2023-01-15T00:00:00.000Z",
"etag": "\"abc123\"",
"storageClass": "STANDARD"
}
],
"count": 1,
"isTruncated": false
}
upload_object
Uploads a file or content to an S3 bucket.
Parameters:
bucketName(string, required): Name of the bucket to upload tokey(string, required): Object key (path) in the bucketfilePath(string, optional): Local file path to uploadcontent(string, optional): String content to uploadcontentType(string, optional): MIME type of the content
Response:
{
"success": true,
"bucketName": "my-bucket",
"key": "folder/file.txt",
"etag": "\"abc123\""
}
download_object
Downloads an object from an S3 bucket.
Parameters:
bucketName(string, required): Name of the bucket to download fromkey(string, required): Object key (path) in the bucketoutputPath(string, optional): Local file path to save the downloaded objectreturnContent(boolean, optional): If true, returns the object content in the response
Response:
{
"success": true,
"bucketName": "my-bucket",
"key": "folder/file.txt",
"outputPath": "/local/path/file.txt",
"content": "File content if returnContent is true",
"contentType": "text/plain",
"size": 1024
}
delete_object
Deletes an object from an S3 bucket.
Parameters:
bucketName(string, required): Name of the bucket containing the objectkey(string, required): Object key (path) to delete
Response:
{
"success": true,
"bucketName": "my-bucket",
"key": "folder/file.txt"
}
get_bucket_policy
Retrieves the policy for an S3 bucket.
Parameters:
bucketName(string, required): Name of the bucket to get the policy for
Response:
{
"success": true,
"bucketName": "my-bucket",
"policy": {
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": "*",
"Action": "s3:GetObject",
"Resource": "arn:aws:s3:::my-bucket/*"
}
]
}
}
set_bucket_policy
Sets or updates the policy for an S3 bucket.
Parameters:
bucketName(string, required): Name of the bucket to set the policy forpolicy(string or object, required): The policy document as a JSON string or object
Response:
{
"success": true,
"bucketName": "my-bucket"
}
License
This project is licensed under the MIT License - see the LICENSE file for details.
Related Servers
Cloudinary MCP Server
Upload images and videos to Cloudinary from compatible MCP clients.
Google Drive MCP
Access and manage your Google Drive files and folders.
Box
File access and search for Box.
WebDAV MCP Server
Perform CRUD operations on a WebDAV server with basic authentication.
Qiniu MCP Server
Access Qiniu's cloud storage, intelligent multimedia services, and CDN operations via the Model Context Protocol.
MCP IPFS Server
Interact with the storacha.network IPFS platform using the w3 CLI.
TOS MCP Server
Explore and retrieve content from Volcengine's Tinder Object Storage (TOS) using natural language queries.
4EVERLAND Hosting
Deploy AI-generated code instantly to decentralized storage networks like Greenfield, IPFS, and Arweave.
Memory Bank MCP
An MCP server for remote memory bank management, enhanced with Supergateway for streamable-http transport. It supports multi-project management and requires persistent storage.
AWS S3
Manage AWS S3 buckets and objects, including policies, tagging, and configurations.