davireis/stackport

By davireis

Updated 3 days ago

Universal AWS resource browser for local emulators (MiniStack, LocalStack, Moto)

Image
Developer tools
Web servers
1

1.9K

davireis/stackport repository overview

StackPort — Universal AWS Resource Browser

StackPort

Universal AWS resource browser for local emulators and real AWS accounts.

Browse, inspect, and manage resources across 35 AWS services with dedicated UIs for S3, DynamoDB, Lambda, SQS, IAM, EC2, CloudWatch Logs, and Secrets Manager.

CI PyPI Version Docker Pulls Docker Image Size License Python GitHub stars

Screenshots

Dashboard — Service overview with resource counts and health status StackPort Dashboard

Lambda Browser — Function list with config, aliases, versions, event sources, and invocation panel Lambda Resources

S3 Browser — File browser with upload, download, folder navigation, and tagging S3 Browser

Features

  • Browse and inspect resources across 35 AWS services
  • 8 dedicated service UIs for S3, DynamoDB, Lambda, SQS, IAM, EC2, CloudWatch Logs, and Secrets Manager
  • Write operations — upload/delete S3 objects, query DynamoDB, invoke Lambda, send/receive SQS messages
  • Real AWS support — connect to real AWS accounts with read-only mode by default
  • Per-endpoint authentication — default credentials, AWS profiles (SSO/AssumeRole), or static keys per endpoint
  • Tag management — unified tagging across 21 resource types
  • CLIstackport status, list, describe, export with JSON/CSV/table output
  • Real-time dashboard with WebSocket-powered live updates
  • Keyboard shortcuts — 16 shortcuts for fast navigation (press ? to view)
  • Single Docker image, works with MiniStack, LocalStack, Moto, or any AWS-compatible endpoint

Quick Start

# Start MiniStack (or LocalStack, Moto, etc.)
pip install ministack && ministack

# Start StackPort
pip install stackport
stackport
# Open http://localhost:8080
With real AWS
# Using AWS profile (read-only by default)
AWS_PROFILE=my-profile stackport

# Using explicit credentials
AWS_ACCESS_KEY_ID=AKIA... AWS_SECRET_ACCESS_KEY=... AWS_REGION=us-west-2 stackport

# Disable write operations (read-only mode)
STACKPORT_ALLOW_WRITES=false AWS_PROFILE=my-profile stackport

You can also configure per-endpoint authentication from the Settings UI — select a profile, enter static credentials, or use the default credential chain per endpoint. See Per-endpoint authentication below.

When connected to real AWS, StackPort shows a warning banner and operates in read-only mode unless writes are explicitly enabled.

Docker Compose (MiniStack + StackPort)

This example uses MiniStack as the emulator, but you can swap it for LocalStack, Moto, or any AWS-compatible endpoint — just update AWS_ENDPOINT_URL.

curl -O https://raw.githubusercontent.com/DaviReisVieira/stackport/main/examples/docker-compose.yml
docker compose up -d
# Open http://localhost:8080
Docker (standalone)
docker run -p 8080:8080 -e AWS_ENDPOINT_URL=http://host.docker.internal:4566 davireis/stackport
Other emulators

StackPort works with any AWS-compatible endpoint — just set AWS_ENDPOINT_URL:

# LocalStack
AWS_ENDPOINT_URL=http://localhost:4566 stackport

# Moto
AWS_ENDPOINT_URL=http://localhost:5000 stackport

# MinIO (S3 only)
AWS_ENDPOINT_URL=http://localhost:9000 stackport

# Any custom endpoint
AWS_ENDPOINT_URL=http://my-emulator:4566 stackport
Multiple endpoints

Switch between multiple AWS endpoints from the UI. Configure named endpoints with STACKPORT_ENDPOINTS:

# Connect to a local emulator and a real AWS account (empty URL = real AWS)
STACKPORT_ENDPOINTS="local=http://localhost:4566,nprod=" \
  AWS_PROFILE=nprod AWS_REGION=us-west-1 stackport

Docker Compose (local + real AWS):

curl -O https://raw.githubusercontent.com/DaviReisVieira/stackport/main/examples/docker-compose.multi-endpoint.yml
docker compose -f docker-compose.multi-endpoint.yml up -d
# Open http://localhost:8080

See examples/docker-compose.multi-endpoint.yml for a full example with MiniStack + real AWS via profile.

The endpoint selector appears in the sidebar when more than one endpoint is configured. Each endpoint is health-checked independently, and all API requests, caches, and WebSocket subscriptions are scoped to the active endpoint.

Per-endpoint authentication

Each endpoint can use its own AWS authentication method, configured from the Settings UI:

Auth TypeDescriptionUse Case
DefaultUses AWS_ACCESS_KEY_ID/AWS_SECRET_ACCESS_KEY env vars or instance roleLocal emulators, EC2/ECS deployments
AWS ProfileUses a named profile from ~/.aws/configSSO, AssumeRole, multiple accounts
Static CredentialsPer-endpoint access key and secretService accounts, cross-account access

Profile auth supports SSO, AssumeRole, and credential_process — anything boto3.Session(profile_name=...) handles. If your SSO token expires, StackPort returns a 401 with instructions to run aws sso login --profile <name>.

Docker users: mount your AWS config to use profiles inside the container:

services:
  stackport:
    image: davireis/stackport
    volumes:
      - ~/.aws:/root/.aws

You can test connections before saving using the "Test Connection" button in the add/edit endpoint dialog.

Service Browsers

Dedicated UIs (8 services)
ServiceBrowseWrite Operations
S3Buckets, objects, folder navigation, searchUpload, download, delete, batch delete, create folders
DynamoDBTables, schema, itemsQuery by partition/sort key, scan
LambdaFunctions, config, aliases, versions, event sourcesInvoke with JSON payload, download code
SQSQueues, messages, attributesSend, receive, delete messages, purge queue
IAMUsers, roles, groups, policies, trust policiesRead-only
EC2Instances, VPCs, subnets, security groups, volumesRead-only
CloudWatch LogsLog groups, streams, events with time filteringRead-only
Secrets ManagerSecrets with value reveal, rotation statusRead-only
Generic Resource Browser (27 services)

All other services use a searchable resource table with JSON detail view, pagination, and export (JSON/CSV).

Tag Management

Unified tag read/write across 21 resource types:

S3 buckets, DynamoDB tables, Lambda functions, SQS queues, IAM users/roles/policies, EC2 instances/security groups/volumes, CloudWatch log groups, Secrets Manager secrets, RDS instances/clusters, SNS topics, KMS keys, ECR repositories, CloudFormation stacks, Step Functions state machines, Kinesis streams, SSM parameters, ELB load balancers, ElastiCache clusters

CLI

# Show service availability and resource counts
stackport status
stackport status --output json

# List resources for a service
stackport list s3
stackport list dynamodb --output csv

# Get resource details
stackport describe s3 buckets my-bucket
stackport describe lambda functions my-func --output json

# Export all resources
stackport export lambda --format json
stackport export ec2 --format csv

All CLI commands accept --endpoint URL and --region REGION overrides.

Keyboard Shortcuts

Press ? anywhere to see all shortcuts.

KeyAction
?Show shortcuts modal
bToggle sidebar
g dGo to Dashboard
g rGo to Resources
/Focus search
j / kNavigate up/down in resource list
[ / ]Previous/next service
EnterOpen selected resource
rRefresh current view
EscClose panel / clear selection

Configuration

VariableDefaultDescription
AWS_ENDPOINT_URL(unset)AWS endpoint. Unset = real AWS via credential chain
AWS_REGIONus-east-1AWS region
AWS_ACCESS_KEY_ID(unset)AWS access key. Unset = use credential chain
AWS_SECRET_ACCESS_KEY(unset)AWS secret key. Unset = use credential chain
AWS_PROFILE(unset)AWS named profile from ~/.aws/credentials
STACKPORT_PORT8080StackPort server port
STACKPORT_ALLOW_WRITEStrueEnable write operations (POST/PUT/DELETE)
STACKPORT_S3_MAX_UPLOAD_MB100Max S3 upload size per object (MiB)
STACKPORT_SERVICES(35 services)Comma-separated list of services to probe
STACKPORT_PROBE_TIMEOUT5Seconds before a service probe times out
STACKPORT_CACHE_TTL5Seconds to cache service stats
STACKPORT_PROBE_WORKERS10Max concurrent workers for service probing
STACKPORT_ENDPOINTS(unset)Multiple endpoints: local=http://localhost:4566,staging=http://...
STACKPORT_DATA_DIR~/.stackportDirectory for persistent config (endpoints.json)
LOG_LEVELINFOPython log level (DEBUG shows healthcheck logs)

Supported Services (35)

ACM, API Gateway, AppSync, Athena, CloudFormation, CloudFront, Cognito (IDP + Identity), DynamoDB, EC2, ECR, ECS, ElastiCache, EFS, ELB, EMR, EventBridge, Firehose, Glue, IAM, Kinesis, KMS, Lambda, CloudWatch Logs, CloudWatch Monitoring, RDS, Route 53, S3, Secrets Manager, SES, SNS, SQS, SSM, Step Functions, STS, WAFv2

Development

git clone https://github.com/DaviReisVieira/stackport.git
cd stackport

# Backend
pip install -e .
AWS_ENDPOINT_URL=http://localhost:4566 stackport

# Frontend dev (with hot reload)
cd ui && npm install && npm run dev

# Build frontend for production
cd ui && npm run build

# Run tests
python -m pytest tests/ -x --tb=short    # backend (362 tests)
cd ui && npx vitest run                   # frontend (176 tests)

# Typecheck & lint
cd ui && npx tsc -b
cd ui && npx eslint .

See CONTRIBUTING.md for full details.

Architecture

backend/
  main.py          FastAPI app, CORS, read-only middleware, SPA mount
  config.py        All settings from environment variables
  aws_client.py    Cached boto3 client factory
  cache.py         Thread-safe TTL cache
  websocket.py     Real-time probe loop for dashboard
  routes/
    stats.py       Service discovery with concurrent probing
    resources.py   Generic list/detail for all services
    endpoints.py   Endpoint CRUD, health checks, profile listing
    tags.py        Unified tag management (21 types)
    s3.py          S3 file browser with write ops
    dynamodb.py    DynamoDB query/scan
    lambda_svc.py  Lambda invoke/config/code
    sqs.py         SQS send/receive/purge
    iam.py         IAM users/roles/groups/policies
    ec2.py         EC2 instances/VPCs/security groups
    logs.py        CloudWatch log streams/events
    secretsmanager.py  Secret value retrieval

ui/src/
  pages/           Dashboard, ResourceBrowser, About
  components/
    service-views/ S3Browser, DynamoDBBrowser, LambdaBrowser, ...
    ui/            shadcn/ui components (Radix-based)
  hooks/           useFetch, useWebSocket, useKeyboardShortcuts, ...
  lib/             API client, types, service icons, utils

Star History

Star History Chart

Contributors

Contributors

License

MIT

Tag summary

Content type

Image

Digest

sha256:8c94590c4

Size

36.5 MB

Last updated

3 days ago

docker pull davireis/stackport:0.3.1