MediatR 13.0.0

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.

Setting the license key

You can set the license key when registering MediatR:

services.AddMediatR(cfg => 
{
    cfg.LicenseKey = "<license key here>";
})

You can register for your license key at MediatR.io

Showing the top 20 packages that depend on MediatR.

Packages Downloads
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
45
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
46
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
48
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
49
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
50
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
51
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
52
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
53
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
58
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
59
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
61
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
189
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
311

Version Downloads Last updated
13.0.0 10 07/04/2025
12.5.0 31 04/05/2025
12.4.1 304 09/13/2024
12.4.0 228 08/03/2024
12.3.0 76 06/27/2024
12.2.0 184 02/04/2024
12.1.1 52 02/09/2024
12.0.1 44 07/21/2024
11.1.0 73 02/04/2024
11.0.0 141 02/04/2024
10.0.1 125 02/04/2024
10.0.0 55 07/21/2024
9.0.0 61 02/05/2024
8.1.0 50 07/21/2024
8.0.2 58 07/21/2024
8.0.1 59 07/21/2024
8.0.0 57 07/21/2024
7.0.0 55 07/21/2024
6.0.0 55 07/21/2024
5.1.0 48 07/21/2024
5.0.1 46 07/21/2024
5.0.1-alpha-0002 63 07/21/2024
5.0.1-alpha-0001 52 07/21/2024
4.1.0 50 07/21/2024
4.0.1 48 07/21/2024
4.0.0 53 07/21/2024
4.0.0-alpha-0002 49 07/21/2024
4.0.0-alpha 56 07/21/2024
3.0.1 48 07/21/2024
3.0.0 49 07/21/2024
2.1.0 57 07/21/2024
2.1.0-beta-19 50 07/21/2024
2.0.2 45 07/21/2024
2.0.1 53 07/21/2024
2.0.0 50 07/21/2024
2.0.0-beta-005 56 07/21/2024
2.0.0-beta-004 54 07/21/2024
2.0.0-beta-003 54 07/21/2024
2.0.0-beta-002 49 07/21/2024
2.0.0-beta-001 55 07/21/2024
1.0.0 56 07/21/2024
0.5.0 49 07/21/2024
0.4.0 51 07/21/2024
0.3.0 45 07/21/2024
0.2.0 48 07/21/2024
0.1.0 56 07/21/2024