FluentValidation 7.6.100

A validation library for .NET that uses a fluent interface to construct strongly-typed validation rules.

Showing the top 20 packages that depend on FluentValidation.

Packages Downloads
Ocelot
Ocelot is an API Gateway. The project is aimed at people using .NET running a micro services / service orientated architecture that need a unified point of entry into their system. In particular I want easy integration with IdentityServer reference and bearer tokens. reference tokens. Ocelot is a bunch of middlewares in a specific order. Ocelot manipulates the HttpRequest object into a state specified by its configuration until it reaches a request builder middleware where it creates a HttpRequestMessage object which is used to make a request to a downstream service. The middleware that makes the request is the last thing in the Ocelot pipeline. It does not call the next middleware. The response from the downstream service is stored in a per request scoped repository and retrived as the requests goes back up the Ocelot pipeline. There is a piece of middleware that maps the HttpResponseMessage onto the HttpResponse object and that is returned to the client. That is basically it with a bunch of other features.
4
Ocelot
Ocelot is an API Gateway. The project is aimed at people using .NET running a micro services / service orientated architecture that need a unified point of entry into their system. In particular I want easy integration with IdentityServer reference and bearer tokens. reference tokens. Ocelot is a bunch of middlewares in a specific order. Ocelot manipulates the HttpRequest object into a state specified by its configuration until it reaches a request builder middleware where it creates a HttpRequestMessage object which is used to make a request to a downstream service. The middleware that makes the request is the last thing in the Ocelot pipeline. It does not call the next middleware. The response from the downstream service is stored in a per request scoped repository and retrived as the requests goes back up the Ocelot pipeline. There is a piece of middleware that maps the HttpResponseMessage onto the HttpResponse object and that is returned to the client. That is basically it with a bunch of other features.
5
Ocelot
Ocelot is an API Gateway. The project is aimed at people using .NET running a micro services / service orientated architecture that need a unified point of entry into their system. In particular I want easy integration with IdentityServer reference and bearer tokens. reference tokens. Ocelot is a bunch of middlewares in a specific order. Ocelot manipulates the HttpRequest object into a state specified by its configuration until it reaches a request builder middleware where it creates a HttpRequestMessage object which is used to make a request to a downstream service. The middleware that makes the request is the last thing in the Ocelot pipeline. It does not call the next middleware. The response from the downstream service is stored in a per request scoped repository and retrived as the requests goes back up the Ocelot pipeline. There is a piece of middleware that maps the HttpResponseMessage onto the HttpResponse object and that is returned to the client. That is basically it with a bunch of other features.
8
Ocelot
This project is aimed at people using .NET running a micro services / service orientated architecture that need a unified point of entry into their system. In particular I want easy integration with IdentityServer reference and bearer tokens. We have been unable to find this in my current workplace without having to write our own Javascript middlewares to handle the IdentityServer reference tokens. We would rather use the IdentityServer code that already exists to do this. Ocelot is a bunch of middlewares in a specific order. Ocelot manipulates the HttpRequest object into a state specified by its configuration until it reaches a request builder middleware where it creates a HttpRequestMessage object which is used to make a request to a downstream service. The middleware that makes the request is the last thing in the Ocelot pipeline. It does not call the next middleware. The response from the downstream service is stored in a per request scoped repository and retrived as the requests goes back up the Ocelot pipeline. There is a piece of middleware that maps the HttpResponseMessage onto the HttpResponse object and that is returned to the client. That is basically it with a bunch of other features.
4
Ocelot
This project is aimed at people using .NET running a micro services / service orientated architecture that need a unified point of entry into their system. In particular I want easy integration with IdentityServer reference and bearer tokens. We have been unable to find this in my current workplace without having to write our own Javascript middlewares to handle the IdentityServer reference tokens. We would rather use the IdentityServer code that already exists to do this. Ocelot is a bunch of middlewares in a specific order. Ocelot manipulates the HttpRequest object into a state specified by its configuration until it reaches a request builder middleware where it creates a HttpRequestMessage object which is used to make a request to a downstream service. The middleware that makes the request is the last thing in the Ocelot pipeline. It does not call the next middleware. The response from the downstream service is stored in a per request scoped repository and retrived as the requests goes back up the Ocelot pipeline. There is a piece of middleware that maps the HttpResponseMessage onto the HttpResponse object and that is returned to the client. That is basically it with a bunch of other features.
5

Changes in 7.6: * WhenAsync now works correctly when calling the non-async Validate method. * ASP.NET Core integration has been updated to ASP.NET Core 2.1. * Include statement now works when explicitly selecting properties to validate. * Added Ukranian language support. * Added Arabic language support. * Added caching when instantiating validators to obtain clientside metadata. Changes in 7.5.2: * RuleSet method can now take multiple ruleset names by usinga comma-separated string. * Make setters on ValidationFailure's properties public to allow for easier deserialization. * Additional overload for OverridePropertyName that takes an expression. * Add overload of Include that takes a func to lazily create the inner validator. * Make error code resolution pluggable using ValidatorOptions.ErrorCodeResolver Changes in 7.5.1: * Resolved issues with referencing FluentValidation from legacy PCLs. * Added support for CustomizeValidatorAttribute to the legacy WebApi integration for consistency with MVC5 and AspNetCore. Changes in 7.5: * Better handling of clientside messages when using custom overriden language resources * Added flag in the ValidationContext's RootDataContext when a validator is invoked by the automatic MVC/WebApi integration * Improvements to some of the validation tester's messages * Added Transform method to transform property values prior to validation * Improve support for DisplayAttribute / DisplayNameAttribute when inferring property display name * New language translations (Slovak/Hebrew/Brazilian Portuguese) * Cache display names by default * Ensure ShouldHaveChildValidator test method works with model-level rules * Removed netstandard1.0 support. Supported platforms are now netstandard1.1, netstandard2.0 and net45. Changes in 7.4: * Improved syntax for DependentRules * ValidationException serialization support when running on full framework * Added ComparisonProperty placeholder to some validators * The Test Helper now correctly handles read-only properties * Add CancellationToken support to ValidateAndThrowAsync and various ValidateAsync overloads * Improved functionality for custom MessageBuilders * Updated AspNetCore integration to MVC version 2.0.2 * Update MVC5 AddToModelState extension not to overwrite existing attempted values * Added SetRulesetForClientsideMessages method for MVC5/AspNetCore as an alternative to using the RulesetForClientSideMessagesAttribute Changes in 7.3: * Major changes to AspNetCore integration including better support for collections and implicit validation (opt-in) * Fix - Updated EnumValidator's Flags support to handle the ~0 value * Fix - TestHelper checking for child validator would respond with the wrong type * Fix - Updated translations for some validators * Fix - Overload of WithName that takes a lambda generated an exception * Added versions of WhenAsync and UnlessAsync that support CancellationTokens * Simplify calls to DependentRules * Add Skip property to CustomizeValidatorAttribute in the ASP.NET Core integration Changes in 7.2: * Updated AspNetCore integration to support IValidatableObject * Updated AspNetCore integration to allow mixing multiple validation strategies in the same model * Updated AspNetCore integration to support RulesetForClientsideMessagesAttribute * Fix - Property names were not generated properly for nested types when using AddFailure inside a Custom validator * Fix - NullReferenceException when using CustomAsync but the validator is invoked synchronously * Fix - Clientside integration in AspNetCore being resolved from the root-level service provider * Fix - Allow empty string to be passed to OverridePropertyName Changes in 7.1.1: * Fix - Incorrect property name was generated when using RuleForEach combined with SetValidator * Fix - Nesting async validators inside DependentRules didn't wait for completion Changes in 7.1: * New RuleFor().Custom() method as a replacement for the old, deprecated Custom method * Improved messages in the ShouldHaveChildValidator test extension * Test helper works with nested properties * Additional overload of WithState allows access to collection item when used with RuleForEach * Fix - Wrong values were generated as part of the MVC5 clientside integration for MinLength and MaxLength validators * Fix - AssemblyScanner now excludes abstract and generic types * Fix - InvalidCastException when using lazy WithMessage combined with RuleForEach * WithState enhanced to allow access to the ValidationContext Changes in 7.0: 7.0 is a major release that contains several breaking changes, especially with Localization. If you use FluentValidation's support for localization please read the updated documentation: https://github.com/JeremySkinner/FluentValidation/wiki/f.-Localization * Localization rewrite to not require satellite assemblies * New 'Custom' rule method replaces the root-level Custom method * Switch to Netstandard based build process * Assemblies are now signed / strongly named - see https://github.com/JeremySkinner/FluentValidation/wiki/l.-Strong-naming-and-signed-packages * Fix - Possible NullReferenceException in the AspNetCore clientside integration for length validators * Fix - Don't clear the ModelValidatorProviders collection by default in the AspNetCore integration (added new ClearValidatorProviders property to control this behaviour) * Fix - Ensure IValidatorFactory is resolved from request scope in asp.net core integration * Fix - Property getter that throws an exception causes validation to fail in WebApi integration * Fix - Issue in AspNetCore integration where we tried to resolve a collection validator in some situations where a class validator should be used * Fix - Incorrect clientside validation attributes generated for email validator and credit card validator in the asp.net core integration * Fix - Child model validation now works in webapi integration * Improve splitting of PascalCased property names to support uppercase character sequences * ValidationResult.ErrorCode property now always returns the type of the PropertyValidator that generated the message, unless it's been explicitly overriden Full release notes can be found at https://github.com/JeremySkinner/FluentValidation/blob/master/Changelog.txt

Version Downloads Last updated
12.0.0-preview1 0 01/02/2025
11.11.0 0 11/16/2024
11.10.0 0 09/15/2024
11.9.2 0 06/10/2024
11.9.1 0 04/23/2024
11.9.0 4 01/04/2024
11.8.1 3 12/03/2023
11.8.0 6 12/30/2023
11.7.1 3 12/30/2023
11.7.0 3 01/20/2024
11.6.0 3 03/01/2024
11.5.2 3 01/13/2024
11.5.1 3 02/08/2024
11.5.0 3 03/02/2024
11.4.0 1 03/12/2024
11.3.0 3 03/01/2024
11.2.2 3 01/19/2024
11.2.1 3 02/08/2024
11.2.0 3 12/26/2023
11.1.1 3 03/02/2024
11.1.0 3 03/01/2024
11.0.3 3 02/08/2024
11.0.2 3 01/23/2024
11.0.1 2 01/24/2024
11.0.0 3 03/01/2024
10.4.0 2 01/19/2024
10.3.6 6 08/18/2023
10.3.5 3 03/01/2024
10.3.4 3 12/18/2023
10.3.3 3 01/07/2024
10.3.1 3 03/02/2024
10.3.0 3 03/01/2024
10.2.3 3 03/01/2024
10.2.2 3 12/11/2023
10.2.1 4 01/18/2024
10.2.0 3 03/25/2024
10.1.0 4 01/05/2024
10.0.4 3 01/08/2024
9.5.4 3 03/02/2024
9.5.3 3 12/30/2023
9.5.2 3 12/23/2023
9.5.1 3 01/23/2024
9.5.0 3 03/02/2024
9.4.0 3 01/13/2024
9.3.0 3 03/01/2024
9.3.0-preview3 1 03/12/2024
9.3.0-preview2 3 03/01/2024
9.3.0-preview1 2 03/13/2024
9.2.2 2 02/08/2024
9.2.1 3 01/19/2024
9.2.0 3 03/02/2024
9.1.3 3 01/07/2024
9.1.2 3 01/12/2024
9.1.1 3 03/02/2024
9.1.0 3 12/18/2023
9.0.1 3 01/06/2024
9.0.0 1 09/26/2024
9.0.0-preview5 2 03/13/2024
9.0.0-preview4 2 03/13/2024
9.0.0-preview3 2 03/13/2024
9.0.0-preview2 2 03/13/2024
9.0.0-preview1 1 03/13/2024
8.6.3 4 03/01/2024
8.6.2 3 03/01/2024
8.6.1 3 03/02/2024
8.6.0 3 03/01/2024
8.5.1 3 02/08/2024
8.5.0 3 03/01/2024
8.5.0-preview5 2 03/16/2024
8.5.0-preview4 2 03/17/2024
8.5.0-preview3 1 03/16/2024
8.5.0-preview2 1 03/14/2024
8.5.0-preview1 2 03/16/2024
8.4.0 1 01/17/2024
8.3.0 3 03/01/2024
8.2.3 3 02/08/2024
8.2.2 3 12/10/2023
8.2.1 3 01/24/2024
8.2.0 3 03/02/2024
8.1.3 2 03/22/2024
8.1.2 3 03/02/2024
8.1.1 4 03/01/2024
8.1.0 3 02/08/2024
8.1.0-preview2 1 03/12/2024
8.1.0-preview1 1 03/13/2024
8.0.101 3 02/08/2024
8.0.100 3 01/19/2024
8.0.0 3 01/06/2024
8.0.0-rc1 2 03/12/2024
8.0.0-preview4 1 03/12/2024
8.0.0-preview3 2 03/12/2024
8.0.0-preview2 1 03/12/2024
7.6.105 1 03/13/2024
7.6.104 1 03/12/2024
7.6.103 2 03/13/2024
7.6.102 2 03/12/2024
7.6.101 1 03/12/2024
7.6.100 2 03/12/2024
7.6.0 3 01/05/2024
7.6.0-preview1 1 03/14/2024
7.5.2 3 03/02/2024
7.5.1 3 02/07/2024
7.5.0 3 03/01/2024
7.4.0 3 01/08/2024
7.3.4 3 02/08/2024
7.3.3 3 03/02/2024
7.3.2 3 03/25/2024
7.3.1 3 03/01/2024
7.3.0 3 03/01/2024
7.3.0-beta3 2 03/12/2024
7.3.0-beta2 1 03/12/2024
7.3.0-beta1 2 03/12/2024
7.2.1 3 01/14/2024
7.2.0 3 03/01/2024
7.2.0-beta3 2 03/13/2024
7.2.0-beta2 1 03/13/2024
7.2.0-beta1 2 03/13/2024
7.1.1 3 03/02/2024
7.1.0 3 12/19/2023
7.1.0-beta1 3 03/02/2024
7.0.3 3 01/17/2024
7.0.2 3 01/14/2024
7.0.1 3 12/22/2023
7.0.0 3 12/18/2023
7.0.0-beta3 2 03/12/2024
7.0.0-beta2 3 02/08/2024
7.0.0-beta1 2 03/12/2024
6.4.1 3 01/08/2024
6.4.1-beta1 2 03/22/2024
6.4.0 3 01/02/2024
6.4.0-rc4 2 03/19/2024
6.4.0-rc3 2 03/18/2024
6.4.0-rc2 2 03/18/2024
6.4.0-rc1 2 03/19/2024
6.4.0-beta9 1 03/18/2024
6.4.0-beta8 1 03/18/2024
6.4.0-beta7 2 03/18/2024
6.4.0-beta6 2 03/18/2024
6.4.0-beta5 2 03/18/2024
6.4.0-beta4 1 03/18/2024
6.4.0-beta3 2 03/18/2024
6.4.0-beta2 1 03/18/2024
6.4.0-beta10 1 03/19/2024
6.4.0-beta1 0 06/28/2016
6.3.4-alpha 2 03/12/2024
6.3.3-alpha 1 03/12/2024
6.2.1 3 01/19/2024
6.2.1-beta1 1 03/13/2024
6.2.0 3 03/01/2024
6.2.0-beta1 2 03/13/2024
6.1.0 4 12/18/2023
6.0.2 3 01/16/2024
6.0.1 3 12/22/2023
6.0.0 3 01/01/2024
5.6.2 3 12/19/2023
5.6.1 3 03/01/2024
5.5.0 3 03/01/2024
5.4.0 2 03/26/2024
5.3.0 3 02/08/2024
5.2.0 3 03/01/2024
5.1.0 3 12/15/2023
5.0.0.1 3 01/03/2024
4.0.0.1 3 02/08/2024
4.0.0 3 03/01/2024
3.4.6 3 03/02/2024
3.4.0 3 01/13/2024
3.3.1 3 03/01/2024
3.2.0 3 03/01/2024
3.1.0 3 12/14/2023
3.0.0.1 3 12/18/2023
3.0.0 3 12/18/2023
2.0.0 3 12/13/2023
1.3.0 3 03/01/2024