MCP Servers

A collection of Model Context Protocol servers, templates, tools and more.

L
Localstack MCP Server

MCP server that exposes LocalStack-managed AWS services as AI-agent tools, enabling LLMs and AI agents to interact with local AWS infrastructure during development and testing.

Created 3/7/2026
Updated 1 day ago
Repository documentation and setup instructions

LocalStack MCP Server

MCP Registry npm

MCP server that exposes LocalStack-managed AWS services as AI-agent tools, enabling LLMs and AI agents to interact with local AWS infrastructure during development and testing.

Installation

The server is published to npm and the MCP Registry. No local build needed.

npm install -g @giovane.martins/localstack

Or run directly with npx (no install required):

npx @giovane.martins/localstack

Requirements

  • Node.js 20+
  • Docker (for LocalStack)

Local Development

# 1. Start LocalStack
docker compose up -d

# 2. Install dependencies
pnpm install

# 3. Build
pnpm run build

# 4. Run
pnpm start

Configuration

All configuration is via environment variables:

| Variable | Default | Description | |---|---|---| | LOCALSTACK_ENDPOINT | http://localhost:4566 | LocalStack base URL | | AWS_REGION | us-east-1 | AWS region | | AWS_ACCESS_KEY_ID | test | Fake credentials for LocalStack | | AWS_SECRET_ACCESS_KEY | test | Fake credentials for LocalStack |

Running Tests

Requires LocalStack running (docker compose up -d).

pnpm test

MCP Client Configuration

Using the published npm package (recommended)

Add to your MCP client config (e.g. ~/.config/claude/claude_desktop_config.json):

{
  "mcpServers": {
    "localstack": {
      "command": "npx",
      "args": ["-y", "@giovane.martins/localstack"],
      "env": {
        "LOCALSTACK_ENDPOINT": "http://localhost:4566",
        "AWS_REGION": "us-east-1",
        "AWS_ACCESS_KEY_ID": "test",
        "AWS_SECRET_ACCESS_KEY": "test"
      }
    }
  }
}

Using a local build

{
  "mcpServers": {
    "localstack": {
      "command": "node",
      "args": ["/path/to/mcp-servers/localstack/dist/index.js"],
      "env": {
        "LOCALSTACK_ENDPOINT": "http://localhost:4566",
        "AWS_REGION": "us-east-1",
        "AWS_ACCESS_KEY_ID": "test",
        "AWS_SECRET_ACCESS_KEY": "test"
      }
    }
  }
}

Using tsx for development (no build step)

{
  "mcpServers": {
    "localstack": {
      "command": "npx",
      "args": ["tsx", "/path/to/mcp-servers/localstack/src/index.ts"],
      "env": {
        "LOCALSTACK_ENDPOINT": "http://localhost:4566",
        "AWS_REGION": "us-east-1",
        "AWS_ACCESS_KEY_ID": "test",
        "AWS_SECRET_ACCESS_KEY": "test"
      }
    }
  }
}

Available Tools

S3

| Tool | Description | |---|---| | s3_list_buckets | List all S3 buckets | | s3_create_bucket | Create a bucket | | s3_delete_bucket | Delete a bucket | | s3_put_object | Upload an object (text/JSON content) | | s3_get_object | Download an object as text | | s3_delete_object | Delete an object | | s3_list_objects | List objects with optional prefix filter |

SQS

| Tool | Description | |---|---| | sqs_list_queues | List all queues | | sqs_create_queue | Create a standard or FIFO queue | | sqs_delete_queue | Delete a queue | | sqs_send_message | Send a message | | sqs_receive_messages | Receive up to 10 messages (with long-polling support) | | sqs_delete_message | Delete a message by receipt handle | | sqs_purge_queue | Purge all messages from a queue |

SNS

| Tool | Description | |---|---| | sns_list_topics | List all topics | | sns_create_topic | Create a standard or FIFO topic | | sns_delete_topic | Delete a topic | | sns_subscribe | Subscribe an endpoint to a topic | | sns_unsubscribe | Unsubscribe from a topic | | sns_list_subscriptions_by_topic | List all subscriptions for a topic | | sns_publish | Publish a message to a topic |

EventBridge

| Tool | Description | |---|---| | eventbridge_list_buses | List all event buses | | eventbridge_create_bus | Create a custom event bus | | eventbridge_delete_bus | Delete a custom event bus | | eventbridge_list_rules | List rules on a bus | | eventbridge_put_rule | Create or update a rule (event pattern or schedule) | | eventbridge_delete_rule | Delete a rule | | eventbridge_describe_rule | Describe a rule | | eventbridge_enable_rule | Enable a rule | | eventbridge_disable_rule | Disable a rule | | eventbridge_put_targets | Add or update rule targets | | eventbridge_list_targets | List targets for a rule | | eventbridge_remove_targets | Remove targets from a rule | | eventbridge_put_events | Send custom events to a bus (max 10) |

Kinesis

| Tool | Description | |---|---| | kinesis_list_streams | List all streams | | kinesis_create_stream | Create a stream | | kinesis_delete_stream | Delete a stream | | kinesis_describe_stream | Describe a stream (status, shards) | | kinesis_put_record | Put a single record | | kinesis_put_records | Put multiple records (max 500) | | kinesis_get_records | Get records from a shard |

DynamoDB

| Tool | Description | |---|---| | dynamodb_list_tables | List all tables | | dynamodb_create_table | Create a table (partition key + optional sort key) | | dynamodb_delete_table | Delete a table | | dynamodb_describe_table | Describe a table | | dynamodb_put_item | Put (create or replace) an item | | dynamodb_get_item | Get an item by key | | dynamodb_delete_item | Delete an item by key | | dynamodb_scan | Scan all items (with optional filter expression) | | dynamodb_query | Query by key condition |

Lambda

| Tool | Description | |---|---| | lambda_list_functions | List all functions | | lambda_get_function | Get function details | | lambda_create_function | Create a function from a base64-encoded ZIP | | lambda_delete_function | Delete a function | | lambda_invoke | Invoke a function and return its response + logs |

Secrets Manager

| Tool | Description | |---|---| | secretsmanager_list_secrets | List all secrets | | secretsmanager_create_secret | Create a new secret | | secretsmanager_get_secret | Get the value of a secret | | secretsmanager_update_secret | Update the value of a secret | | secretsmanager_describe_secret | Describe secret metadata | | secretsmanager_delete_secret | Delete a secret (with optional force delete) | | secretsmanager_restore_secret | Restore a previously deleted secret |

SSM Parameter Store

| Tool | Description | |---|---| | ssm_get_parameter | Get a parameter by name | | ssm_put_parameter | Create or update a parameter | | ssm_delete_parameter | Delete a parameter | | ssm_delete_parameters | Delete up to 10 parameters in batch | | ssm_get_parameters_by_path | Get all parameters under a path prefix | | ssm_describe_parameters | List and describe parameters |

SES

| Tool | Description | |---|---| | ses_list_identities | List all verified identities | | ses_verify_email_identity | Verify an email address | | ses_get_identity_verification_attributes | Get verification status for identities | | ses_delete_identity | Delete an identity | | ses_send_email | Send an email (plain text and/or HTML) |


Use Cases

  • Dev environment bootstrap — create S3 buckets, SQS queues, DynamoDB tables, and SSM parameters in one shot from a spec
  • Test data seeding — populate DynamoDB or S3 before running integration tests
  • Event-driven debugging — publish to EventBridge/SNS/Kinesis and inspect downstream effects without leaving the IDE
  • Secret/config management — read and update Secrets Manager / SSM values during local debug sessions
  • Lambda smoke testing — invoke Lambda functions, capture responses and logs, iterate quickly
  • Queue drain / inspect — receive and inspect SQS messages without a consumer running

Project Structure

localstack/
├── docker-compose.yml      # LocalStack container
├── package.json
├── tsconfig.json
├── vitest.config.ts
├── src/
│   ├── index.ts            # MCP server entry point
│   ├── config.ts           # Environment config
│   ├── tools/              # One file per AWS service
│   │   ├── s3.ts
│   │   ├── sqs.ts
│   │   ├── sns.ts
│   │   ├── eventbridge.ts
│   │   ├── kinesis.ts
│   │   ├── dynamodb.ts
│   │   ├── lambda.ts
│   │   ├── secretsmanager.ts
│   │   ├── ssm.ts
│   │   └── ses.ts
│   └── utils/
│       ├── client.ts       # Shared AWS client factory (LocalStack endpoint)
│       └── errors.ts       # Standardised MCP error formatting
└── tests/                  # Integration tests (real LocalStack)
    ├── s3.test.ts
    ├── sqs.test.ts
    ├── sns.test.ts
    ├── eventbridge.test.ts
    ├── kinesis.test.ts
    ├── dynamodb.test.ts
    ├── lambda.test.ts
    ├── secretsmanager.test.ts
    ├── ssm.test.ts
    └── ses.test.ts
Quick Setup
Installation guide for this server

Install Package (if required)

npx @modelcontextprotocol/server-localstack-mcp-server

Cursor configuration (mcp.json)

{ "mcpServers": { "giovanemartins-localstack-mcp-server": { "command": "npx", "args": [ "giovanemartins-localstack-mcp-server" ] } } }