Middleman 1.0.2
See the version list below for details.
dotnet add package Middleman --version 1.0.2
NuGet\Install-Package Middleman -Version 1.0.2
<PackageReference Include="Middleman" Version="1.0.2" />
<PackageVersion Include="Middleman" Version="1.0.2" />
<PackageReference Include="Middleman" />
paket add Middleman --version 1.0.2
#r "nuget: Middleman, 1.0.2"
#:package Middleman@1.0.2
#addin nuget:?package=Middleman&version=1.0.2
#tool nuget:?package=Middleman&version=1.0.2
<img src="https://raw.githubusercontent.com/jajao1/Middleman/main/logo.png" alt="Middleman Logo" width="48" height="48" align="center" /> Middleman 🤝
Middleman is a lightweight, in-process mediator library for .NET focused on CQRS-style request/query dispatching and notification (event) publication.
Installation
dotnet add package Middleman
Target Frameworks
- Middleman: net9.0, netstandard2.0
- Middleman.FluentValidation: net9.0
Core Concepts
IMiddleman: Main dispatcher interface (send, publish, stream).IRequest<TResponse>: Request/query with a single response.IRequest: Request with no response.IStreamRequest<TResponse>: Request/query that returnsIAsyncEnumerable<TResponse>.INotification: Marker for published events/notifications.
Quick Start
1) Define Contracts
using Middleman;
public sealed class CreateUserRequest : IRequest<Guid>
{
public CreateUserRequest(string name) => Name = name;
public string Name { get; }
}
public sealed class UserCreatedNotification : INotification
{
public UserCreatedNotification(Guid userId) => UserId = userId;
public Guid UserId { get; }
}
2) Implement Handlers
using Middleman;
public sealed class CreateUserRequestHandler : IRequestHandler<CreateUserRequest, Guid>
{
private readonly IMiddleman _middleman;
public CreateUserRequestHandler(IMiddleman middleman)
{
_middleman = middleman;
}
public async Task<Guid> Handle(CreateUserRequest message, CancellationToken cancellationToken)
{
var id = Guid.NewGuid();
await _middleman.Publish(new UserCreatedNotification(id), cancellationToken);
return id;
}
}
public sealed class UserCreatedLogger : INotificationHandler<UserCreatedNotification>
{
public Task Handle(UserCreatedNotification notification, CancellationToken cancellationToken)
{
Console.WriteLine($"User created: {notification.UserId}");
return Task.CompletedTask;
}
}
3) Register in DI
using System.Reflection;
using Middleman;
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddMiddleman(Assembly.GetExecutingAssembly(), options =>
{
options.PublishStrategy = NotificationPublishStrategy.Parallel;
options.ContinueOnException = false;
});
// Optional: enable in-memory request response caching
builder.Services.AddMiddlemanCaching();
4) Dispatch
var id = await middleman.Send(new CreateUserRequest("joao"), cancellationToken);
Release Notes (March 2026)
Added
Core package multi-target support for net9.0 and netstandard2.0
Centralized exception handling behavior
IExceptionHandler<TRequest, TResponse>IExceptionHandler<TRequest>ExceptionHandlingBehavior<TRequest, TResponse>ExceptionHandlingBehavior<TRequest>
Response caching behavior for requests
ICacheableRequest<TResponse>CachingBehavior<TRequest, TResponse>AddMiddlemanCaching()
Configurable notification publish strategies
MiddlemanOptionsNotificationPublishStrategy.ParallelNotificationPublishStrategy.SequentialContinueOnException
Async stream request support
IStreamRequest<TResponse>IStreamRequestHandler<TRequest, TResponse>CreateStream<TResponse>(...)on sender/dispatcher
Internal Improvements
- Safer reflective invocation for handlers and pipeline behaviors.
- Expanded xUnit coverage for exception handling, caching, publish strategy, and streaming.
API Overview
| Interface | Description |
|---|---|
IMiddleman |
Central dispatcher (send, publish, stream). |
ISender |
Send requests and create streams. |
IPublisher |
Publish notifications/events. |
IRequest<TResponse> |
Request/query with response. |
IRequest |
Request without response. |
IStreamRequest<TResponse> |
Stream request/query with async stream response. |
INotification |
Notification/event marker. |
IRequestHandler<,> / IRequestHandler<> |
Request handlers. |
IStreamRequestHandler<,> |
Stream request handlers. |
INotificationHandler<TNotification> |
Notification handlers. |
Contributing
Contributions are welcome. Open an issue or submit a pull request.
License
This project is licensed under the MIT License. See LICENSE for details.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. 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 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. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Microsoft.Bcl.AsyncInterfaces (>= 9.0.9)
- Microsoft.Extensions.Caching.Memory (>= 8.0.1)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.9)
-
net10.0
- Microsoft.Extensions.Caching.Memory (>= 9.0.9)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.9)
-
net8.0
- Microsoft.Extensions.Caching.Memory (>= 9.0.9)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.9)
-
net9.0
- Microsoft.Extensions.Caching.Memory (>= 9.0.9)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.9)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Middleman:
| Package | Downloads |
|---|---|
|
Middleman.FluentValidation
Middleman is a lightweight .NET library that acts as a central dispatcher for requests and notifications. It allows you to decouple business logic, resulting in a more organized, testable, and maintainable architecture that follows the principles of CQRS and event-driven design. |
GitHub repositories
This package is not used by any popular GitHub repositories.