Headless.Domain.LocalPublisher
0.4.15
dotnet add package Headless.Domain.LocalPublisher --version 0.4.15
NuGet\Install-Package Headless.Domain.LocalPublisher -Version 0.4.15
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Headless.Domain.LocalPublisher" Version="0.4.15" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Headless.Domain.LocalPublisher" Version="0.4.15" />
<PackageReference Include="Headless.Domain.LocalPublisher" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Headless.Domain.LocalPublisher --version 0.4.15
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Headless.Domain.LocalPublisher, 0.4.15"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Headless.Domain.LocalPublisher@0.4.15
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Headless.Domain.LocalPublisher&version=0.4.15
#tool nuget:?package=Headless.Domain.LocalPublisher&version=0.4.15
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Headless.Domain.LocalPublisher
DI-based implementation of ILocalMessagePublisher for in-process domain event handling.
Problem Solved
Provides in-memory local message publishing that resolves handlers from the DI container, enabling decoupled event-driven architecture within a single process.
Key Features
ILocalMessagePublisherimplementation using DI- Automatic handler discovery and resolution
- Handler ordering via
LocalEventHandlerOrderAttribute - Sync and async publishing support
- Scoped handler resolution
Installation
dotnet add package Headless.Domain.LocalPublisher
Quick Start
var builder = WebApplication.CreateBuilder(args);
// Register local message publisher
builder.Services.AddLocalMessagePublisher();
// Register handlers (automatically discovered or explicit)
builder.Services.AddScoped<ILocalMessageHandler<OrderCreatedEvent>, OrderCreatedHandler>();
Publishing Events
public sealed class OrderService(ILocalMessagePublisher publisher)
{
public async Task CreateOrderAsync(Order order, CancellationToken ct)
{
await _repository.AddAsync(order, ct).ConfigureAwait(false);
await publisher.PublishAsync(new OrderCreatedEvent(order.Id), ct).ConfigureAwait(false);
}
}
Handling Events
public sealed class OrderCreatedHandler : ILocalMessageHandler<OrderCreatedEvent>
{
public async Task HandleAsync(OrderCreatedEvent message, CancellationToken ct)
{
// Send email, update read model, etc.
}
}
[LocalEventHandlerOrder(1)] // Execute first
public sealed class AuditHandler : ILocalMessageHandler<OrderCreatedEvent>
{
public Task HandleAsync(OrderCreatedEvent message, CancellationToken ct)
{
// Audit logging
return Task.CompletedTask;
}
}
Configuration
No configuration required.
Dependencies
Headless.DomainHeadless.Hosting
Side Effects
- Registers
ILocalMessagePublisheras scoped
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | 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. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net10.0
- CommunityToolkit.HighPerformance (>= 8.4.2)
- FluentValidation (>= 12.1.1)
- Headless.Domain (>= 0.4.15)
- Headless.Hosting (>= 0.4.15)
- Humanizer.Core (>= 3.0.10)
- IdGen (>= 3.0.7)
- JetBrains.Annotations (>= 2025.2.4)
- libphonenumber-csharp (>= 9.0.30)
- Microsoft.Bcl.TimeProvider (>= 10.0.8)
- Microsoft.Extensions.Configuration.Abstractions (>= 10.0.8)
- Microsoft.Extensions.DependencyInjection (>= 10.0.8)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.8)
- Microsoft.Extensions.Hosting (>= 10.0.8)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.8)
- Microsoft.Extensions.Logging (>= 10.0.8)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.8)
- Microsoft.Extensions.Logging.Console (>= 10.0.8)
- Microsoft.Extensions.Options (>= 10.0.8)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 10.0.8)
- Microsoft.Extensions.Options.DataAnnotations (>= 10.0.8)
- morelinq (>= 4.4.0)
- Nito.AsyncEx (>= 5.1.2)
- Nito.Disposables (>= 2.5.0)
- Polly.Core (>= 8.6.6)
- Scrutor (>= 7.0.0)
- System.Reactive (>= 6.1.0)
- TimeZoneConverter (>= 7.2.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.