LocalStack.Aspire.Hosting
9.4.0-rc.1
dotnet add package LocalStack.Aspire.Hosting --version 9.4.0-rc.1
NuGet\Install-Package LocalStack.Aspire.Hosting -Version 9.4.0-rc.1
<PackageReference Include="LocalStack.Aspire.Hosting" Version="9.4.0-rc.1" />
<PackageVersion Include="LocalStack.Aspire.Hosting" Version="9.4.0-rc.1" />
<PackageReference Include="LocalStack.Aspire.Hosting" />
paket add LocalStack.Aspire.Hosting --version 9.4.0-rc.1
#r "nuget: LocalStack.Aspire.Hosting, 9.4.0-rc.1"
#:package LocalStack.Aspire.Hosting@9.4.0-rc.1
#addin nuget:?package=LocalStack.Aspire.Hosting&version=9.4.0-rc.1&prerelease
#tool nuget:?package=LocalStack.Aspire.Hosting&version=9.4.0-rc.1&prerelease
.NET Aspire Integrations for LocalStack
A .NET Aspire hosting integration for LocalStack that enables local development and testing of cloud applications using AWS services. This package extends the official AWS integrations for .NET Aspire to provide LocalStack-specific functionality.
⚠️ Release Candidate: This package is currently in Release Candidate (RC) status. While the core functionality is stable and production-ready, the API surface may still evolve based on community feedback before the final release.
Installation
dotnet add package LocalStack.Aspire.Hosting
Package Note: The package is named
LocalStack.Aspire.Hosting
but uses the namespaceAspire.Hosting.LocalStack
to align with .NET Aspire hosting conventions. This ensures consistency with other Aspire hosting integrations while maintaining a unique package identity.
Requirements: .NET 8.0 or later (supports both .NET 8 and .NET 9)
Development Builds
For access to the latest features and bug fixes:
# Add GitHub Packages source
dotnet nuget add source https://nuget.pkg.github.com/localstack-dotnet/index.json \
--name github-localstack-for-aspire \
--username YOUR_GITHUB_USERNAME \
--password YOUR_GITHUB_TOKEN
# Install development packages
dotnet add package LocalStack.Aspire.Hosting --prerelease --source github-localstack-for-aspire
Note: GitHub Packages requires a Personal Access Token with
read:packages
permission.
Usage
When LocalStack is disabled in configuration, both host and client configurations automatically fall back to real AWS services without requiring code changes. The LocalStack.NET Client automatically switches to AWS's official client factory when LocalStack is not enabled.
Host Configuration (AppHost)
Configure LocalStack integration in your Aspire AppHost project using auto-configuration:
var builder = DistributedApplication.CreateBuilder(args);
// 1. Set up AWS SDK configuration (optional)
var awsConfig = builder.AddAWSSDKConfig()
.WithProfile("default")
.WithRegion(RegionEndpoint.USWest2);
// 2. Add LocalStack container
var localstack = builder
.AddLocalStack(awsConfig: awsConfig, configureContainer: container =>
{
container.Lifetime = ContainerLifetime.Session;
container.DebugLevel = 1;
container.LogLevel = LocalStackLogLevel.Debug;
});
// 3. Add your AWS resources as usual
var awsResources = builder.AddAWSCloudFormationTemplate("resources", "template.yaml")
.WithReference(awsConfig);
var project = builder.AddProject<Projects.MyService>("api")
.WithReference(awsResources);
// 4. Auto-configure LocalStack for all AWS resources
builder.UseLocalStack(localstack);
builder.Build().Run();
The UseLocalStack()
method automatically:
- Detects all AWS resources (CloudFormation, CDK stacks)
- Configures LocalStack endpoints for all AWS services and project resources
- Sets up proper dependency ordering and CDK bootstrap if needed
- Transfers LocalStack configuration to service projects via environment variables
Manual Configuration
For fine-grained control, you can manually configure each resource:
var awsResources = builder.AddAWSCloudFormationTemplate("resources", "template.yaml")
.WithReference(localstack) // Manual LocalStack reference
.WithReference(awsConfig);
var project = builder.AddProject<Projects.MyService>("api")
.WithReference(localstack) // Manual project reference
.WithReference(awsResources);
Client Configuration (Service Projects)
Configure AWS services in your service projects using LocalStack.NET Client (2M+ downloads, production-tested):
var builder = WebApplication.CreateBuilder(args);
// Add LocalStack configuration
builder.Services.AddLocalStack(builder.Configuration);
// Register AWS services - automatically configured for LocalStack when enabled
builder.Services.AddAwsService<IAmazonS3>();
builder.Services.AddAwsService<IAmazonDynamoDB>();
builder.Services.AddAwsService<IAmazonSNS>();
var app = builder.Build();
This configuration automatically detects if LocalStack is enabled and configures the AWS SDK clients accordingly. If LocalStack is not enabled, it falls back to the official AWS SDK configuration without requiring code changes.
(Alternatively,
AddAWSServiceLocalStack
method can be used to prevent mix-up with AddAWSService.
For more details on client configuration options, see the LocalStack.NET Client documentation.
Configuration Integration
The LocalStack.Aspire.Hosting
host automatically transfers LocalStack configuration to service projects via environment variables. This works with the standard .NET configuration hierarchy: appsettings.json files → Environment variables (can override appsettings) → Command line arguments
Important: Ensure your service projects include the EnvironmentVariablesConfigurationProvider in the correct order for automatic configuration to work.
Features
- Auto-Configuration: Single
UseLocalStack()
call automatically detects and configures all AWS resources - Manual Configuration: Fine-grained control with explicit
WithReference()
calls for each resource - AWS Service Integration: Works with CloudFormation templates, CDK stacks, and AWS service clients
- Automatic Fallback: Falls back to real AWS services when LocalStack is disabled
- Container Lifecycle Management: Configurable container with session/project lifetime options
- Extension-Based: Works alongside official AWS integrations for .NET Aspire without code changes
Examples
Complete Working Examples
- Provisioning Examples - SNS, SQS, DynamoDB with CloudFormation & CDK
- Serverless Examples - Lambda functions with API Gateway and hybrid emulators
Both examples demonstrate auto-configuration and manual configuration approaches.
What is LocalStack?
LocalStack is a cloud service emulator that runs in a single container on your laptop or in your CI environment. It provides a fully functional local AWS cloud stack, allowing you to develop and test your cloud applications offline.
Contributing
We welcome contributions from the community! Here's how you can get involved:
- Try it out: Clone the repository and test the playground examples
- Report issues: Share bugs or feature requests via GitHub issues
- Submit improvements: Pull requests for enhancements and bug fixes
- Share feedback: Join discussions about the implementation and roadmap
For detailed contribution guidelines, development setup, and coding standards, see our Contributing Guide.
Changelog
See CHANGELOG.md for a detailed history of changes, new features, and breaking changes for each release.
Related Projects
- Aspire - Aspire is a unified toolchain that simplifies building, debugging, and deploying observable, production-ready distributed apps through a code-first app model.
- AWS Integrations for .NET Aspire - Official AWS integrations that this project extends
- LocalStack .NET Client - The .NET client library for LocalStack that we integrate with
License
This project is licensed under the MIT License - see the LICENSE file for details.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net8.0
- Aspire.Hosting (>= 9.4.0)
- Aspire.Hosting.AWS (>= 9.2.6)
- LocalStack.Client (>= 2.0.0)
-
net9.0
- Aspire.Hosting (>= 9.4.0)
- Aspire.Hosting.AWS (>= 9.2.6)
- LocalStack.Client (>= 2.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last Updated |
---|---|---|
9.4.0-rc.1 | 274 | 8/7/2025 |