- Notifications
You must be signed in to change notification settings - Fork2.2k
Simple, unambitious mediator implementation in .NET
License
LuckyPennySoftware/MediatR
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
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 thewiki.
You should installMediatR 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.
To reference only the contracts for MediatR, which includes:
IRequest
(including generic variants)INotification
IStreamRequest
Add a package reference toMediatR.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
MediatR supportsMicrosoft.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.
You can set the license key when registering MediatR:
services.AddMediatR(cfg=>{cfg.LicenseKey="<license key here>";})
Or if not using Microsoft.Extensions.DependencyInjection:
Mediator.LicenseKey="<license key here>";
Tip
The license key does not need to be set on client applications (such as Blazor WASM).Turn off the license warning by configuring logging in your logging start configuration:builder.Logging.AddFilter("LuckyPennySoftware.MediatR.License", LogLevel.None);
You can register for your license key atMediatR.io
About
Simple, unambitious mediator implementation in .NET
Topics
Resources
License
Uh oh!
There was an error while loading.Please reload this page.