IronAlpine.Mediator.DependencyInjection
2.0.0
dotnet add package IronAlpine.Mediator.DependencyInjection --version 2.0.0
NuGet\Install-Package IronAlpine.Mediator.DependencyInjection -Version 2.0.0
<PackageReference Include="IronAlpine.Mediator.DependencyInjection" Version="2.0.0" />
<PackageVersion Include="IronAlpine.Mediator.DependencyInjection" Version="2.0.0" />
<PackageReference Include="IronAlpine.Mediator.DependencyInjection" />
paket add IronAlpine.Mediator.DependencyInjection --version 2.0.0
#r "nuget: IronAlpine.Mediator.DependencyInjection, 2.0.0"
#:package IronAlpine.Mediator.DependencyInjection@2.0.0
#addin nuget:?package=IronAlpine.Mediator.DependencyInjection&version=2.0.0
#tool nuget:?package=IronAlpine.Mediator.DependencyInjection&version=2.0.0
IronAlpine.Mediator.DependencyInjection
Why
Provides DI registration helpers for mediator services and behavior registration.
Installation
dotnet add package IronAlpine.Mediator.DependencyInjection
Program.cs
builder.Services.AddIronAlpineMediator(cfg =>
{
cfg.RegisterServicesFromAssembly(typeof(AssemblyReference).Assembly);
cfg.AddOpenBehavior(typeof(LoggingBehavior<,>));
cfg.AddOpenBehavior(typeof(CachingBehavior<,>));
cfg.AddOpenBehavior(typeof(ValidationBehavior<,>));
cfg.AddOpenBehavior(typeof(TransactionBehavior<,>));
});
Notes
Behavior ordering is deterministic by registration order. Keep this explicit.
Configuration Deep Dive
When a package exposes options classes, use builder.Configuration binding and keep values explicit per environment.
Common guidance:
- Prefer explicit values in production.
- Keep retries/timeouts conservative; tune with telemetry.
- Enable startup validation in non-development environments.
- Fail fast when required dependencies are missing.
Integration Patterns
Pattern A: API service with EF + Messaging
- Register EF provider package.
- Register messaging inbox/outbox package.
- Register mediator and behavior order.
- Enable health readiness checks for DB and broker.
Pattern B: Read-heavy service with Dapper + Messaging
- Register Dapper data package.
- Register messaging package with consumer enabled.
- Add observability and structured logging.
Pattern C: Security-focused service
- Register security ASP.NET package.
- Add policy catalog or resolver.
- Register authorization EFCore projection package only where needed.
Options Checklist
Use this checklist when configuring any IronAlpine package:
- Required connection strings present.
- Feature flags intentional (
Enable*values reviewed). - Retry and timeout values match SLO expectations.
- Startup validation behavior understood.
- Environment-specific defaults are overridden in production.
Troubleshooting Matrix
- Startup failure with validation error : A required dependency package or config value is missing. Check package registrations and bound options sections.
- Background workers not starting
: Verify execution mode,
Enable*flags, and hosted services registration. - Policy/authorization mismatch : Check claim types, policy naming strategy, and catalog entries.
- Cache stale or no-hit behavior : Validate key generation, invalidation path, and distributed lock configuration.
- Messaging duplicate handling issues
: Verify
event-idpropagation and idempotency key construction.
Best-Practice Notes
- Keep handler logic deterministic and side-effect boundaries explicit.
- Keep
IQueryableusage inside application handlers/services. - Keep transaction save boundaries in handlers where business intent is clear.
- Prefer explicit topic policy metadata for critical events.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | 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 is compatible. 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. |
-
net10.0
- IronAlpine.Mediator (>= 2.0.0)
- IronAlpine.Mediator.Abstractions (>= 2.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.7)
-
net9.0
- IronAlpine.Mediator (>= 2.0.0)
- IronAlpine.Mediator.Abstractions (>= 2.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.7)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Stable patch release: DI registration hardening and compatibility alignment.