MediatR 12.4.1

MediatR

CI NuGet NuGet MyGet (dev)

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 transient
  • ISender as transient
  • IPublisher as transient
  • IRequestHandler<,> concrete implementations as transient
  • IRequestHandler<> concrete implementations as transient
  • INotificationHandler<> concrete implementations as transient
  • IStreamRequestHandler<> concrete implementations as transient
  • IRequestExceptionHandler<,,> concrete implementations as transient
  • IRequestExceptionAction<,>) 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
27
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
28
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
29
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
30
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
31
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
32
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
34
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
35
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
37
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
38
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
42
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
43
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
55
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
1,997
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
11,520
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
12,371

Version Downloads Last updated
12.4.1 13 09/13/2024
12.4.0 12 08/03/2024
12.3.0 10 06/09/2024
12.2.0 15 11/18/2023
12.1.1 13 07/11/2023
12.1.0 17 01/20/2024
12.0.1 36 05/17/2023
11.1.0 56 12/08/2022
11.0.0 13,357 10/12/2022
10.0.1 1,958 06/27/2022
10.0.0 27 08/13/2022
9.0.0 11,519 06/27/2022
8.1.0 23 08/13/2022
8.0.2 19 08/13/2022
8.0.1 45 08/13/2022
8.0.0 19 08/13/2022
7.0.0 23 08/13/2022
6.0.0 25 08/19/2022
5.1.0 25 08/13/2022
5.0.1 26 08/13/2022
5.0.1-alpha-0002 32 08/13/2022
5.0.1-alpha-0001 49 08/13/2022
4.1.0 21 08/13/2022
4.0.1 58 06/27/2022
4.0.0 21 08/13/2022
4.0.0-alpha-0002 49 08/13/2022
4.0.0-alpha 65 08/12/2022
3.0.1 23 08/13/2022
3.0.0 27 08/13/2022
2.1.0 29 07/01/2022
2.1.0-beta-19 23 08/13/2022
2.0.2 59 07/01/2022
2.0.1 22 08/13/2022
2.0.0 26 08/13/2022
2.0.0-beta-005 55 08/13/2022
2.0.0-beta-004 49 08/12/2022
2.0.0-beta-003 42 07/02/2022
2.0.0-beta-002 23 08/13/2022
2.0.0-beta-001 24 08/13/2022
1.0.0 31 08/13/2022
0.5.0 64 08/13/2022
0.4.0 21 08/13/2022
0.3.0 53 07/01/2022
0.2.0 26 08/13/2022
0.1.0 24 08/13/2022