npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@giovane.martins/localstack

v1.1.5

Published

MCP server for LocalStack AWS services

Readme

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