MediatR 12.5.0
MediatR
Simple mediator implementation in .NET
In-process messaging with no dependencies.
Supports request/response, commands, queries, notifications and events, synchronous and async with intelligent dispatching via C# generic variance.
Examples in the wiki.
Installing MediatR
You should install MediatR with NuGet:
Install-Package MediatR
Or via the .NET Core command line interface:
dotnet add package MediatR
Either commands, from Package Manager Console or .NET Core CLI, will download and install MediatR and all required dependencies.
Using Contracts-Only Package
To reference only the contracts for MediatR, which includes:
IRequest
(including generic variants)INotification
IStreamRequest
Add a package reference to MediatR.Contracts
This package is useful in scenarios where your MediatR contracts are in a separate assembly/project from handlers. Example scenarios include:
- API contracts
- GRPC contracts
- Blazor
Registering with IServiceCollection
MediatR supports Microsoft.Extensions.DependencyInjection.Abstractions
directly. To register various MediatR services and handlers:
services.AddMediatR(cfg => cfg.RegisterServicesFromAssemblyContaining<Startup>());
or with an assembly:
services.AddMediatR(cfg => cfg.RegisterServicesFromAssembly(typeof(Startup).Assembly));
This registers:
IMediator
as transientISender
as transientIPublisher
as transientIRequestHandler<,>
concrete implementations as transientIRequestHandler<>
concrete implementations as transientINotificationHandler<>
concrete implementations as transientIStreamRequestHandler<>
concrete implementations as transientIRequestExceptionHandler<,,>
concrete implementations as transientIRequestExceptionAction<,>)
concrete implementations as transient
This also registers open generic implementations for:
INotificationHandler<>
IRequestExceptionHandler<,,>
IRequestExceptionAction<,>
To register behaviors, stream behaviors, pre/post processors:
services.AddMediatR(cfg => {
cfg.RegisterServicesFromAssembly(typeof(Startup).Assembly);
cfg.AddBehavior<PingPongBehavior>();
cfg.AddStreamBehavior<PingPongStreamBehavior>();
cfg.AddRequestPreProcessor<PingPreProcessor>();
cfg.AddRequestPostProcessor<PingPongPostProcessor>();
cfg.AddOpenBehavior(typeof(GenericBehavior<,>));
});
With additional methods for open generics and overloads for explicit service types.
Showing the top 20 packages that depend on MediatR.
Packages | Downloads |
---|---|
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
|
32 |
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
|
33 |
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
|
34 |
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
|
36 |
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
|
37 |
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
|
39 |
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
|
42 |
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
|
49 |
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
|
132 |
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
|
246 |
.NET 6.0
- MediatR.Contracts (>= 2.0.1 && < 3.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.0)
.NET Standard 2.0
- MediatR.Contracts (>= 2.0.1 && < 3.0.0)
- Microsoft.Bcl.AsyncInterfaces (>= 8.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.0)
Version | Downloads | Last updated |
---|---|---|
12.5.0 | 4 | 04/05/2025 |
12.4.1 | 146 | 09/13/2024 |
12.4.0 | 178 | 08/03/2024 |
12.3.0 | 59 | 06/27/2024 |
12.2.0 | 160 | 02/04/2024 |
12.1.1 | 35 | 02/09/2024 |
12.0.1 | 32 | 07/21/2024 |
11.1.0 | 55 | 02/04/2024 |
11.0.0 | 116 | 02/04/2024 |
10.0.1 | 103 | 02/04/2024 |
10.0.0 | 37 | 07/21/2024 |
9.0.0 | 43 | 02/05/2024 |
8.1.0 | 35 | 07/21/2024 |
8.0.2 | 42 | 07/21/2024 |
8.0.1 | 40 | 07/21/2024 |
8.0.0 | 39 | 07/21/2024 |
7.0.0 | 39 | 07/21/2024 |
6.0.0 | 37 | 07/21/2024 |
5.1.0 | 32 | 07/21/2024 |
5.0.1 | 27 | 07/21/2024 |
5.0.1-alpha-0002 | 46 | 07/21/2024 |
5.0.1-alpha-0001 | 35 | 07/21/2024 |
4.1.0 | 32 | 07/21/2024 |
4.0.1 | 33 | 07/21/2024 |
4.0.0 | 38 | 07/21/2024 |
4.0.0-alpha-0002 | 31 | 07/21/2024 |
4.0.0-alpha | 38 | 07/21/2024 |
3.0.1 | 30 | 07/21/2024 |
3.0.0 | 33 | 07/21/2024 |
2.1.0 | 37 | 07/21/2024 |
2.1.0-beta-19 | 34 | 07/21/2024 |
2.0.2 | 28 | 07/21/2024 |
2.0.1 | 37 | 07/21/2024 |
2.0.0 | 34 | 07/21/2024 |
2.0.0-beta-005 | 38 | 07/21/2024 |
2.0.0-beta-004 | 39 | 07/21/2024 |
2.0.0-beta-003 | 37 | 07/21/2024 |
2.0.0-beta-002 | 30 | 07/21/2024 |
2.0.0-beta-001 | 35 | 07/21/2024 |
1.0.0 | 39 | 07/21/2024 |
0.5.0 | 34 | 07/21/2024 |
0.4.0 | 35 | 07/21/2024 |
0.3.0 | 28 | 07/21/2024 |
0.2.0 | 31 | 07/21/2024 |
0.1.0 | 33 | 07/21/2024 |