One.More.Lib.For.MediatR 2.0.2

dotnet add package One.More.Lib.For.MediatR --version 2.0.2                
NuGet\Install-Package One.More.Lib.For.MediatR -Version 2.0.2                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="One.More.Lib.For.MediatR" Version="2.0.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add One.More.Lib.For.MediatR --version 2.0.2                
#r "nuget: One.More.Lib.For.MediatR, 2.0.2"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install One.More.Lib.For.MediatR as a Cake Addin
#addin nuget:?package=One.More.Lib.For.MediatR&version=2.0.2

// Install One.More.Lib.For.MediatR as a Cake Tool
#tool nuget:?package=One.More.Lib.For.MediatR&version=2.0.2                

One More Lib For MediatR

CI NuGet

As the name suggests, a new library that extends MediatR with integrated PipelineBehavior:

  • Performance Logger
  • MemoryCache
  • Validation with FluentValidation
  • Retry Pattern with Polly

Installing One.More.Lib.For.MediatR

Link to the nuget package

We recommend using NuGet:

Install-Package One.More.Lib.For.MediatR

Or via the .NET Core command line interface:

dotnet add package One.More.Lib.For.MediatR

Performance Logger PipelineBehavior

How to configure it?

The simplest way:

builder.Services.AddMediatRExtensions(configuration => configuration.PerformanceLoggerSupport = true);

If you want to configure it:

builder.Services.AddMediatRExtensions(configuration => configuration.AddPerformanceLoggerSupport(500));

How yo use it?

Nothing to do. Requests will be loggued.

MemoryCache PipelineBehavior

How to configure it?

The simplest way:

builder.Services.AddMediatRExtensions(configuration => configuration.MemoryCacheSupport = true);

If you want a complete configuration:

builder.Services.AddMediatRExtensions(configuration => configuration.AddMemoryCacheSupport(slidingExpiration: TimeSpan.FromMinutes(10), priority: CacheItemPriority.Low));

Or create a specific configuration for a given request:

builder.Services.AddMediatRExtensions(cfg =>
{
  cfg.AddMemoryCacheSupport(slidingExpiration: TimeSpan.FromMinutes(10), priority: CacheItemPriority.Low);
  cfg.AddMemoryCacheSupportOverrideFor<GiveRequest>(priority: CacheItemPriority.High);
}

How yo use it?

Just add [MemoryCache] attribute on requests classes or records.

[MemoryCache]
public class GetUserByName : IRequest<User?>
{
    public string Name { get; set; }
}

Or you can configure more option request by request.

[MemoryCache(Absolute)]
public class GetUserByName : IRequest<User?>
{
    public string Name { get; set; }
}

Validation with FluentValidation

How to configure it?

There is not simplest way because you need to enter the assemblies to be scanned for FluentValidation:

builder.Services.AddMediatRExtensions(configuration => configuration.AddFluentValidationSupport(new[] { typeof(Program).Assembly }));

How to use it?

Nothing to do, just create Validation rules. If a rule is not respected a ValidationException will be thrown.

Retry Pattern with Polly

How to configure it?

The simplest way:

builder.Services.AddMediatRExtensions(configuration => configuration.RetrySupport = true);

If you want to configure it:

builder.Services.AddMediatRExtensions(configuration => configuration.AddRetrySupport(retryCount: 3, retryDelay: 100));

How to use it?

Just add [RetryPolicy] attribute on requests classes or records.

[RetryPolicy]
public class GetUserByName : IRequest<User?>
{
    public string Name { get; set; }
}

Or you can override default values by passing them in the RetryPolicy Attribute

[RetryPolicy(OverrideRetryCount = true, RetryCount = 5)]
public class GetUserByName : IRequest<User?>
{
    public string Name { get; set; }
}
[RetryPolicy(OverrideRetryDelay = true, RetryDelay = 200)]
public class GetUserByName : IRequest<User?>
{
    public string Name { get; set; }
}
Product Compatible and additional computed target framework versions.
.NET net7.0 is compatible.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.0.2 141 4/1/2024
2.0.1 113 3/31/2024
2.0.0 132 3/7/2024
1.0.2 129 2/8/2024
1.0.1 116 2/8/2024
1.0.0 154 10/13/2023