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
Elsa.Abstractions
Elsa is a set of workflow libraries and tools that enable lean and mean workflowing capabilities in any .NET Core application. This package provides abstractions and models that are used by Elsa.Core and other related packages. You don't need to reference this package separately if you reference any other Elsa package.
10
Elsa.Abstractions
Elsa is a set of workflow libraries and tools that enable lean and mean workflowing capabilities in any .NET Core application. This package provides abstractions and models that are used by Elsa.Core and other related packages. You don't need to reference this package separately if you reference any other Elsa package.
11
Elsa.Core
Elsa is a set of workflow libraries and tools that enable lean and mean workflowing capabilities in any .NET Core application. This package contains the core of Elsa. Tip: reference the `Elsa` package instead of this one.
9
Elsa.Core
Elsa is a set of workflow libraries and tools that enable lean and mean workflowing capabilities in any .NET Core application. This package contains the core of Elsa. Tip: reference the `Elsa` package instead of this one.
10
Elsa.Core
Elsa is a set of workflow libraries and tools that enable lean and mean workflowing capabilities in any .NET Core application. This package contains the core of Elsa. Tip: reference the `Elsa` package instead of this one.
11
Elsa.Core
Elsa is a set of workflow libraries and tools that enable super-fast workflowing capabilities in any .NET Core application. This package contains the heart and soul of what makes Elsa tick. It implements most of the abstractions defined in Elsa.Abstractions. If you reference the Elsa package, which is recommended, you don;t have to explicitly reference this package.
10
Elsa.Core
Elsa is a set of workflow libraries and tools that enable super-fast workflowing capabilities in any .NET Core application. This package contains the heart and soul of what makes Elsa tick. It implements most of the abstractions defined in Elsa.Abstractions. If you reference the Elsa package, which is recommended, you don;t have to explicitly reference this package.
11
Elsa.Core
Elsa is a set of workflow libraries and tools that enable super-fast workflowing capabilities in any .NET Core application. This package contains the heart and soul of what makes Elsa tick. It implements most of the abstractions defined in Elsa.Abstractions. If you reference the Elsa package, which is recommended, you don;t have to explicitly reference this package.
12
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
10
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
11
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
12
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
14
MediatR.Extensions.Microsoft.DependencyInjection
MediatR extensions for ASP.NET Core
15

Version Downloads Last updated
12.4.1 5 11/10/2024
12.4.0 3 12/09/2024
12.3.0 6 11/20/2024
12.2.0 11 05/30/2024
12.1.1 10 05/30/2024
12.0.1 9 05/30/2024
11.1.0 8 05/30/2024
11.0.0 11 12/13/2023
10.0.1 10 07/12/2022
10.0.0 9 05/30/2024
9.0.0 10 04/12/2023
8.1.0 8 05/30/2024
8.0.2 10 05/30/2024
8.0.1 8 05/30/2024
8.0.0 10 11/04/2022
7.0.0 6 05/30/2024
6.0.0 9 05/30/2024
5.1.0 7 05/30/2024
5.0.1 8 05/30/2024
5.0.1-alpha-0002 10 05/30/2024
5.0.1-alpha-0001 8 05/30/2024
4.1.0 13 05/30/2024
4.0.1 12 05/30/2024
4.0.0 13 05/30/2024
4.0.0-alpha-0002 11 05/30/2024
4.0.0-alpha 7 05/30/2024
3.0.1 11 05/30/2024
3.0.0 7 05/30/2024
2.1.0 9 05/30/2024
2.1.0-beta-19 10 05/30/2024
2.0.2 7 05/30/2024
2.0.1 10 05/30/2024
2.0.0 10 05/30/2024
2.0.0-beta-005 12 05/30/2024
2.0.0-beta-004 9 05/30/2024
2.0.0-beta-003 11 05/30/2024
2.0.0-beta-002 9 05/30/2024
2.0.0-beta-001 9 05/30/2024
1.0.0 9 05/30/2024
0.5.0 11 05/30/2024
0.4.0 12 05/30/2024
0.3.0 10 05/30/2024
0.2.0 12 05/30/2024
0.1.0 12 05/30/2024