micro-elements - MicroElements.Swashbuckle.FluentValidation 7.1.7

Swagger ISchemaFilter that uses FluentValidation validators instead System.ComponentModel based attributes.

PM> Install-Package MicroElements.Swashbuckle.FluentValidation -Version 7.1.7 -Source https://www.myget.org/F/micro-elements/api/v3/index.json

Copy to clipboard

> nuget.exe install MicroElements.Swashbuckle.FluentValidation -Version 7.1.7 -Source https://www.myget.org/F/micro-elements/api/v3/index.json

Copy to clipboard

> dotnet add package MicroElements.Swashbuckle.FluentValidation --version 7.1.7 --source https://www.myget.org/F/micro-elements/api/v3/index.json

Copy to clipboard
<PackageReference Include="MicroElements.Swashbuckle.FluentValidation" Version="7.1.7" />
Copy to clipboard
source https://www.myget.org/F/micro-elements/api/v3/index.json

nuget MicroElements.Swashbuckle.FluentValidation  ~> 7.1.7
Copy to clipboard

> choco install MicroElements.Swashbuckle.FluentValidation --version 7.1.7 --source https://www.myget.org/F/micro-elements/api/v2

Copy to clipboard
Import-Module PowerShellGet
Register-PSRepository -Name "micro-elements" -SourceLocation "https://www.myget.org/F/micro-elements/api/v2"
Install-Module -Name "MicroElements.Swashbuckle.FluentValidation" -RequiredVersion "7.1.7" -Repository "micro-elements" 
Copy to clipboard

MicroElements.Swashbuckle.FluentValidation

Use FluentValidation rules instead of ComponentModel attributes to define swagger schema.

Note: For WebApi see: https://github.com/micro-elements/MicroElements.Swashbuckle.FluentValidation.WebApi

Statuses

License NuGetVersion NuGetDownloads MyGetVersion

Build and publish AppVeyor Coverage Status

Gitter

Supporting the project

MicroElements.Swashbuckle.FluentValidation is developed and supported by @petriashev for free in his spare time. If you find MicroElements.Swashbuckle.FluentValidation useful, please consider financially supporting the project via OpenCollective which will help keep the project going 🙏.

Usage

1. Minimal API

MinimalApi.csproj

<Project Sdk="Microsoft.NET.Sdk.Web">

    <PropertyGroup>
        <TargetFramework>net8.0</TargetFramework>
        <Nullable>enable</Nullable>
        <ImplicitUsings>enable</ImplicitUsings>
    </PropertyGroup>

    <ItemGroup>
        <PackageReference Include="FluentValidation.AspNetCore" Version="11.3.1" />
        <PackageReference Include="MicroElements.Swashbuckle.FluentValidation" Version="7.1.6" />
        <PackageReference Include="Swashbuckle.AspNetCore" Version="8.1.1" />
    </ItemGroup>
    
</Project>

Program.cs

using FluentValidation;
using FluentValidation.AspNetCore;
using MicroElements.Swashbuckle.FluentValidation.AspNetCore;

var builder = WebApplication.CreateBuilder(args);
var services = builder.Services;

// Asp.Net stuff
services.AddControllers();
services.AddEndpointsApiExplorer();

// Add Swagger
services.AddSwaggerGen();

// Add FV
services.AddFluentValidationAutoValidation();
services.AddFluentValidationClientsideAdapters();

// Add FV validators
services.AddValidatorsFromAssemblyContaining<Program>();

// Add FV Rules to swagger
services.AddFluentValidationRulesToSwagger();

var app = builder.Build();

// Use Swagger
app.UseSwagger();
app.UseSwaggerUI();

app.MapControllers();

app.Run();

2. AspNetCore WebApi

Reference packages in your web project

<PackageReference Include="FluentValidation.AspNetCore" Version="11.3.1" />
<PackageReference Include="MicroElements.Swashbuckle.FluentValidation" Version="7.1.6" />
<PackageReference Include="Swashbuckle.AspNetCore" Version="8.1.1" />

Change Startup.cs

// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{
    // Asp.net stuff
    services.AddControllers();
    
    // HttpContextValidatorRegistry requires access to HttpContext
    services.AddHttpContextAccessor();

    // Register FV validators
    services.AddValidatorsFromAssemblyContaining<Startup>(lifetime: ServiceLifetime.Scoped);

    // Add FV to Asp.net
    services.AddFluentValidationAutoValidation();

    // Add swagger
    services.AddSwaggerGen(c =>
    {
        c.SwaggerDoc("v1", new OpenApiInfo { Title = "My API", Version = "v1" });
    });

    // [Optional] Add INameResolver (SystemTextJsonNameResolver will be registered by default)
    // services.AddSingleton<INameResolver, CustomNameResolver>();

    // Adds FluentValidationRules staff to Swagger. (Minimal configuration)
    services.AddFluentValidationRulesToSwagger();

    // [Optional] Configure generation options for your needs. Also can be done with services.Configure<SchemaGenerationOptions>
    // services.AddFluentValidationRulesToSwagger(options =>
    // {
    //     options.SetNotNullableIfMinLengthGreaterThenZero = true;
    //     options.UseAllOffForMultipleRules = true;
    // });

    // Adds logging
    services.AddLogging(builder => builder.AddConsole());
}

// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
    app.UseRouting();

    app.UseEndpoints(endpoints =>
    {
        endpoints.MapControllers();
    });

    // Adds swagger
    app.UseSwagger();

    // Adds swagger UI
    app.UseSwaggerUI(c =>
    {
        c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");
    });
}

Version compatibility

MicroElements.Swashbuckle.FluentValidation Swashbuckle.AspNetCore FluentValidation
[1.1.0, 2.0.0) [3.0.0, 4.0.0) >=7.2.0
[2.0.0, 3.0.0) [4.0.0, 5.0.0) >=8.1.3
[3.0.0, 3.1.0) [5.0.0, 5.2.0) >=8.3.0
[3.1.0, 4.2.1) [5.2.0, 6.0.0) >=8.3.0
[4.2.0, 5.0.0) [5.5.1, 7.0.0) [9.0.0, 10)
[5.0.0, 6.0.0) [6.3.0, 7.0.0) [10.0.0, 12)
[7.0.0, 8.0.0) [8.0.0, 11.0.0) [11.0.0, 13)

.NET 8/9 use Swashbuckle 8.x (Microsoft.OpenApi 1.x); .NET 10 uses Swashbuckle 10.x (Microsoft.OpenApi 2.x).

Sample application

See sample project: https://github.com/micro-elements/MicroElements.Swashbuckle.FluentValidation/tree/master/samples/SampleWebApi

Supported validators

  • INotNullValidator (NotNull)
  • INotEmptyValidator (NotEmpty)
  • ILengthValidator (for strings: Length, MinimumLength, MaximumLength, ExactLength) (for arrays: MinItems, MaxItems)
  • IRegularExpressionValidator (Email, Matches)
  • IComparisonValidator (GreaterThan, GreaterThanOrEqual, LessThan, LessThanOrEqual)
  • IBetweenValidator (InclusiveBetween, ExclusiveBetween)

File uploads (media types & size) — Issue #216

Validation rules written on nested IFormFile members (e.g. RuleFor(x => x.File.ContentType) / RuleFor(x => x.File.Length)) are not reflected in the OpenAPI document: FluentValidation names them File.ContentType / File.Length, which never match the flat File schema property, and Must(...) carries no introspectable metadata. Use the dedicated File-level rules instead:

using MicroElements.OpenApi.FluentValidation.FileUpload;

public class UploadProductImageRequestValidator : AbstractValidator<UploadProductImageRequest>
{
    public UploadProductImageRequestValidator()
    {
        RuleFor(x => x.File)
            .NotNull()                                    // required
            .FileContentType("image/jpeg", "image/png")   // allowed media types
            .MaxFileSize(2 * 1024 * 1024);                // 2 MB
    }
}

These rules enforce the constraints at runtime and drive the OpenAPI output:

multipart/form-data:
  schema:
    properties:
      File:
        type: string
        format: binary
        description: "Allowed content types: image/jpeg, image/png. Maximum file size: 2097152 bytes."
  encoding:
    File:
      contentType: "image/jpeg, image/png"

Available rules: .FileContentType(params string[]), .MaxFileSize(long), .MinFileSize(long), .FileSizeBetween(long, long).

Backend support:

Backend size & content types in description machine-readable encoding.contentType
Swashbuckle ✅ (net8/9 = OpenAPI 3.0; net10 = OpenAPI 3.1)
NSwag ✅ via FluentValidationOperationProcessor (serialized as encodingType — a known NSwag limitation)
Microsoft.AspNetCore.OpenApi ✅ (net9 + net10)

The issue scenario — making the generated OpenAPI document reflect the allowed content types and size limit — works on all three backends, both via the file part description and as the machine-readable encoding.contentType.

Notes:

  • File size has no standard OpenAPI/JSON-Schema byte keyword, so it is documented in description only (annotation, not enforced by consumers; enforcement stays server-side via FluentValidation).
  • NSwag requires registering the operation processor: settings.OperationProcessors.Add(serviceProvider.GetService<FluentValidationOperationProcessor>()) (see the NSwag sample).
  • Microsoft.AspNetCore.OpenApi: on net10 the file part is emitted as a $ref to a shared IFormFile component, so the size/content-type description is shared across all IFormFile endpoints (differing per-endpoint rules would accumulate there) — but encoding.contentType is per-operation and unaffected.

Extensibility

You can register FluentValidationRule in ServiceCollection.

User defined rule name replaces default rule with the same. Full list of default rules can be get by FluentValidationRules.CreateDefaultRules()

List or default rules:

  • Required
  • NotEmpty
  • Length
  • Pattern
  • Comparison
  • Between

Example of rule:

new FluentValidationRule("Pattern")
{
    Matches = propertyValidator => propertyValidator is IRegularExpressionValidator,
    Apply = context =>
    {
        var regularExpressionValidator = (IRegularExpressionValidator)context.PropertyValidator;
        context.Schema.Properties[context.PropertyKey].Pattern = regularExpressionValidator.Expression;
    }
},

Samples

Swagger Sample model and validator

public class Sample
{
    public string PropertyWithNoRules { get; set; }

    public string NotNull { get; set; }
    public string NotEmpty { get; set; }
    public string EmailAddress { get; set; }
    public string RegexField { get; set; }

    public int ValueInRange { get; set; }
    public int ValueInRangeExclusive { get; set; }

    public float ValueInRangeFloat { get; set; }
    public double ValueInRangeDouble { get; set; }
}

public class SampleValidator : AbstractValidator<Sample>
{
    public SampleValidator()
    {
        RuleFor(sample => sample.NotNull).NotNull();
        RuleFor(sample => sample.NotEmpty).NotEmpty();
        RuleFor(sample => sample.EmailAddress).EmailAddress();
        RuleFor(sample => sample.RegexField).Matches(@"(\d{4})-(\d{2})-(\d{2})");

        RuleFor(sample => sample.ValueInRange).GreaterThanOrEqualTo(5).LessThanOrEqualTo(10);
        RuleFor(sample => sample.ValueInRangeExclusive).GreaterThan(5).LessThan(10);

        // WARNING: Swashbuckle implements minimum and maximim as int so you will loss fraction part of float and double numbers
        RuleFor(sample => sample.ValueInRangeFloat).InclusiveBetween(1.1f, 5.3f);
        RuleFor(sample => sample.ValueInRangeDouble).ExclusiveBetween(2.2, 7.5f);
    }
}

Swagger Sample model screenshot

SwaggerSample

Validator with Include

public class CustomerValidator : AbstractValidator<Customer>
{
    public CustomerValidator()
    {
        RuleFor(customer => customer.Surname).NotEmpty();
        RuleFor(customer => customer.Forename).NotEmpty().WithMessage("Please specify a first name");

        Include(new CustomerAddressValidator());
    }
}

internal class CustomerAddressValidator : AbstractValidator<Customer>
{
    public CustomerAddressValidator()
    {
        RuleFor(customer => customer.Address).Length(20, 250);
    }
}

Nested objects (SetValidator / ChildRules)

Rules for a nested object are applied to the child component schema, and the parent property keeps a $ref to it. Both a standalone child validator (SetValidator) and inline ChildRules are supported (inline ChildRules $ref preservation was fixed in 7.1.6, see #198):

public class CreateUserRequest
{
    public CreateUserParams User { get; set; }
}

public class CreateUserParams
{
    public string Email { get; set; }
    public string Name { get; set; }
}

public class CreateUserRequestValidator : AbstractValidator<CreateUserRequest>
{
    public CreateUserRequestValidator()
    {
        // Inline child rules — no separate validator class required
        RuleFor(x => x.User)
            .NotEmpty()
            .ChildRules(user =>
            {
                user.RuleFor(u => u.Email).NotEmpty().EmailAddress();
                user.RuleFor(u => u.Name).NotEmpty().MaximumLength(510);
            });

        // Equivalent with a standalone validator:
        // RuleFor(x => x.User).NotEmpty().SetValidator(new CreateUserParamsValidator());
    }
}

The Email/Name constraints (and required) end up on the CreateUserParams component, while the parent stays a reference:

"CreateUserRequest": {
  "required": [ "user" ],
  "type": "object",
  "properties": {
    "user": { "$ref": "#/components/schemas/CreateUserParams" }
  }
}

Get params bounded to validatable models

MicroElements.Swashbuckle.FluentValidation updates swagger schema for operation parameters bounded to validatable models.

Nested [FromQuery] parameters

When a [FromQuery] model has nested objects, ASP.NET Core flattens them into dot-path parameters (e.g. RequiredSubType.SubProperty). The validation rules for such a nested parameter are reflected in the OpenAPI document only when they are actually enforced at runtime:

  • The nested validator must be wired from the root validator via SetValidator/ChildRules (since 7.1.7). FluentValidation never auto-validates a child object just because a validator for it is registered in DI — so an unwired nested validator no longer leaks required/length/pattern constraints onto the parameter.
  • A nested parameter is marked required only when every ancestor segment of the dot-path is required (see #209).

Note: if there is no validator registered for the root [FromQuery] type (only a leaf/child validator), the flattened nested parameter is left unconstrained — matching the default runtime, where no validation runs without a root validator. If you instead validate the child manually in the controller (e.g. new SubValidator().Validate(filter.Child)), those constraints cannot be detected statically and so are not reflected in the schema — register/wire a validator for the root type if you want them documented.

Defining rules dynamically from database

See BlogValidator in sample.

Common problems and workarounds

Error: System.InvalidOperationException: 'Cannot resolve 'IValidator<T>' from root provider because it requires scoped service 'TDependency'

Workarounds in order or preference:

Workaround 1 (Use HttpContextServiceProviderValidatorFactory) by @WarpSpideR

public void ConfigureServices(IServiceCollection services)
{
    // HttpContextServiceProviderValidatorFactory requires access to HttpContext
    services.AddHttpContextAccessor();

    services
        .AddMvc()
        // Adds fluent validators to Asp.net
        .AddFluentValidation(c =>
        {
            c.RegisterValidatorsFromAssemblyContaining<Startup>();
            // Optionally set validator factory if you have problems with scope resolve inside validators.
            c.ValidatorFactoryType = typeof(HttpContextServiceProviderValidatorFactory);
        });

Workaround 2 (Use ScopedSwaggerMiddleware)

Replace UseSwagger for UseScopedSwagger:

public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
    app
        .UseMvc()
        // Use scoped swagger if you have problems with scoped services in validators
        .UseScopedSwagger();

Workaround 3 (Set ValidateScopes to false)

public static IWebHost BuildWebHost(string[] args) =>
    WebHost.CreateDefaultBuilder(args)
        // Needed for using scoped services (for example DbContext) in validators
        .UseDefaultServiceProvider(options => options.ValidateScopes = false)
        .UseStartup<Startup>()
        .Build();

Problem: I cant use several validators of one type

Example: You split validator into several small validators but AspNetCore uses only one of them.

Workaround: Hide dependent validators with internal and use Include to include other validation rules to one "Main" validator.

Problem: I'm using FluentValidation or FluentValidation.DependencyInjectionExtensions instead of FluentValidation.AspNetCore

If you are using the more basic FluentValidation or FluentValidation.DependencyInjectionExtensions libraries, then they will not automatically register IValidatorFactory and you will get an error at runtime: "ValidatorFactory is not provided. Please register FluentValidation." In that case you must register it manually (see issue 97 for more details):

services.TryAddTransient<IValidatorFactory, ServiceProviderValidatorFactory>();
services.AddFluentValidationRulesToSwagger();

Problem: Newtonsoft.Json DefaultNamingStrategy, SnakeCaseNamingStrategy does not work


Startup.cs:

    .AddJsonOptions(options =>
    {
        options.JsonSerializerOptions.PropertyNamingPolicy = new NewtonsoftJsonNamingPolicy(new SnakeCaseNamingStrategy());
        //options.JsonSerializerOptions.DictionaryKeyPolicy = new NewtonsoftJsonNamingPolicy(new SnakeCaseNamingStrategy());
    })


    /// <summary>
    /// Allows use Newtonsoft <see cref="NamingStrategy"/> as System.Text <see cref="JsonNamingPolicy"/>.
    /// </summary>
    public class NewtonsoftJsonNamingPolicy : JsonNamingPolicy
    {
        private readonly NamingStrategy _namingStrategy;

        /// <summary>
        /// Creates new instance of <see cref="NewtonsoftJsonNamingPolicy"/>.
        /// </summary>
        /// <param name="namingStrategy">Newtonsoft naming strategy.</param>
        public NewtonsoftJsonNamingPolicy(NamingStrategy namingStrategy)
        {
            _namingStrategy = namingStrategy;
        }

        /// <inheritdoc />
        public override string ConvertName(string name)
        {
            return _namingStrategy.GetPropertyName(name, false);
        }
    }

Credits

Initial version of this project was based on Mujahid Daud Khan answer on StackOverflow: https://stackoverflow.com/questions/44638195/fluent-validation-with-swagger-in-asp-net-core/49477995#49477995

$# Changes in 7.1.7

  • Fixed: The nested [FromQuery] fixes (#209 + #211) now also apply to the native Microsoft.AspNetCore.OpenApi transformer and the experimental Swashbuckle DocumentFilter (Issue #213)
    • FluentValidationOperationTransformer (package MicroElements.AspNetCore.OpenApi.FluentValidation) previously set a nested parameter required from the leaf validator alone — ignoring both whether the SetValidator/ChildRules chain reaches the leaf (#211) and whether every ancestor of the dot-path is required (#209). It now follows the same reachability + ancestor-required rules as the Swashbuckle OperationFilter
    • The experimental FluentValidationDocumentFilter no longer copies value constraints onto a flattened nested parameter whose nested validation is not wired from the root validator (#211)
    • GetMethodInfo now resolves the action method from ControllerActionDescriptor (MVC controllers), not only minimal-API endpoint metadata, so the dot-path root type can be resolved for controller actions
    • NSwag is unaffected (it has no [FromQuery] parameter flattening)
  • Fixed: A validator for a nested type bound via [FromQuery] was reflected in the OpenAPI document even when it was not wired into the root validator via SetValidator/ChildRules (Issue #211)
    • FluentValidationOperationFilter resolved the leaf container's validator directly from the registry (by ModelMetadata.ContainerType), so a nested NotEmpty() marked the flattened parameter (e.g. RequiredSubType.SubProperty) as required even though FluentValidation never validates an unwired child object — the OpenAPI doc claimed required, but the API accepted requests without it
    • Fix: for a flattened nested parameter, nested rules are now applied only when the SetValidator/ChildRules chain from the action's root [FromQuery] validator actually reaches the leaf container; otherwise the parameter is left unconstrained, matching runtime behavior
    • When the root container type cannot be resolved, prior behavior is preserved (no regression for existing nested-parameter scenarios)
    • Behavioral change: when no validator is registered for the root [FromQuery] type (only a leaf/child validator is registered), a flattened nested parameter is now left unconstrained — matching runtime, where no validation runs without a root validator
  • Fixed: A required leaf property inside an optional nested type bound via [FromQuery] was wrongly marked as a required parameter (Issue #209)
    • The 7.1.1 fix (Issue #162) made nested [FromQuery] validation match the leaf property name, but FluentValidationOperationFilter then set required based solely on the leaf type, ignoring whether the ancestor segment of the dot-path was optional
    • Because two nested properties of the same leaf type share one schema/validator (e.g. OptionalSubType.SubProperty and RequiredSubType.SubProperty), a NotEmpty() on the leaf marked both flattened parameters as required
    • Fix: a flattened nested parameter is now marked required only when every ancestor segment of the dot-path is required — resolved from the action's root [FromQuery] type, combining the native schema required (e.g. the C# required modifier) with FluentValidation NotNull/NotEmpty rules
    • Value constraints (e.g. minLength) still apply to an optional nested parameter when it is provided
    • When the root container type cannot be resolved, prior behavior is preserved (no regression for existing nested-parameter scenarios)

Changes in 7.1.6

  • Fixed: $ref still replaced with an inline copy (and the child component left orphaned) when nested object constraints come from ChildRules or an inline child validator (Issue #198, comment 4601720562)
    • The 7.1.3 fix restored unmodified $refs, but when the nested type had no standalone validator its component schema gained its Required only after the parent's inline snapshot, so the stale Required diverged and defeated the restore check — leaving an inline copy and an orphaned component
    • Fix: the Required comparison in HasValidationConstraintChanges is now directional — restoration is only blocked when the inline copy carries a required entry the component lacks
    • SetValidator (with a standalone child validator) was already correct; BigInteger/enum per-model constraints (Issues #146/#176) continue to work
  • Added: ConditionalRulesMode option to control how .When()/.Unless() conditional rules are handled during schema generation (Issue #203)
    • Exclude (default): conditional rules are excluded from the schema (backward-compatible, existing behavior)
    • Include: conditional rules are included in the schema (useful when .When() is a null-guard and constraints should still appear)
    • IncludeWithWarning: same as Include but logs a warning for each conditional rule included
    • Usage: options.ConditionalRules = ConditionalRulesMode.Include;
  • Fixed: Multiple .Matches() rules on one property displayed incorrectly — only the first pattern shown, property duplicated (Issue #204)
    • Multiple patterns were placed into separate allOf subschemas, which Swagger UI/Redoc/Scalar collapse, keeping only the first pattern
    • Now multiple .Matches() rules are combined into a single pattern via lookahead assertions (e.g. (?=[\s\S]*(?:[a-z]))(?=[\s\S]*(?:[A-Z]))), preserving .Matches() semantics and rendering correctly
    • Applied to all providers: Swashbuckle, MicroElements.AspNetCore.OpenApi.FluentValidation, and NSwag (NSwag previously kept only the last pattern)
    • Changed: SchemaGenerationOptions.UseAllOfForMultipleRules default truefalse; set it to true to keep the legacy allOf representation

Changes in 7.1.4

  • Added: FluentValidationOperationTransformer (IOpenApiOperationTransformer) for MicroElements.AspNetCore.OpenApi.FluentValidation (Issue #200)
    • Query parameters with [AsParameters] now receive validation constraints (min/max, required, pattern, etc.)
    • Supports container type resolution with fallback via reflection for [AsParameters]
    • Copies validation constraints from schema properties to parameter schemas
    • Registered automatically via AddFluentValidationRules()
  • Fixed: Nested DTOs in request body not receiving validation constraints (Issue #200)
    • FluentValidationSchemaTransformer skipped all property-level schemas, but for nested object types this was the only transformer call
    • Now processes property-level schemas for complex types using the property type's validator

Changes in 7.1.3

  • Fixed: $ref replaced with inline schema copy when using SetValidator with nested object types (Issue #198)
    • ResolveRefProperty (introduced in 7.1.2 for BigInteger isolation) replaced all $ref properties with copies, destroying reference structure in the OpenAPI document
    • Fix: snapshot $ref properties before rule application, restore them afterwards if no validation constraints were added by rules
    • BigInteger per-model constraints (Issue #146) continue to work correctly

Changes in 7.1.2

  • Added: BigInteger support for min/max validation constraints in OpenAPI schema generation (Issue #146)
    • IsNumeric() and NumericToDecimal() now handle BigInteger values
    • BigInteger properties with GreaterThan, LessThan, InclusiveBetween, ExclusiveBetween rules produce correct minimum/maximum in Swagger
    • NSwag provider updated with the same BigInteger support
    • Out-of-range BigInteger values (exceeding decimal range) are handled gracefully via existing try/catch
  • Fixed: Shared schema mutation when multiple models reference the same BigInteger type with different constraints (net10.0)
    • ResolveRefProperty creates an isolated shallow copy before applying rule mutations
    • Prevents $ref-based schema corruption across models in SchemaRepository
  • Fixed: Replaced deprecated PackageLicenseUrl with PackageLicenseExpression (Issue #144)
  • Fixed: Replaced deprecated PackageIconUrl with embedded PackageIcon

Full release notes can be found at: https://github.com/micro-elements/MicroElements.Swashbuckle.FluentValidation/blob/master/CHANGELOG.md

  • .NETFramework 10.0
    • MicroElements.OpenApi.FluentValidation (>= 7.1.7)
    • Swashbuckle.AspNetCore.SwaggerGen (>= 10.0.0)
  • .NETFramework 8.0
    • MicroElements.OpenApi.FluentValidation (>= 7.1.7)
    • Swashbuckle.AspNetCore.SwaggerGen (>= 8.1.1)
  • .NETFramework 9.0
    • MicroElements.OpenApi.FluentValidation (>= 7.1.7)
    • Swashbuckle.AspNetCore.SwaggerGen (>= 8.1.1)
  • .NETFramework 8.0: 8.0.0.0
  • .NETFramework 9.0: 9.0.0.0
  • .NETFramework 10.0: 10.0.0.0

Owners

avgalex Alexey Petryashev

Authors

alexey.petriashev, MicroElements

Project URL

https://github.com/micro-elements/MicroElements.Swashbuckle.FluentValidation

License

MIT

Tags

swagger swashbuckle FluentValidation aspnetcore

Info

6732 total downloads
2 downloads for version 7.1.7
Download (163.88 KB)
Found on the current feed only

Package history

Version Size Last updated Downloads Mirrored?
7.1.8-beta.2 169.32 KB Sun, 21 Jun 2026 10:40:51 GMT 0
7.1.8-beta.1 169.38 KB Sat, 20 Jun 2026 17:47:11 GMT 2
7.1.7 163.88 KB Sat, 20 Jun 2026 12:54:05 GMT 2
7.1.7-beta.3 163.93 KB Wed, 17 Jun 2026 20:24:30 GMT 3
7.1.7-beta.2 162.41 KB Wed, 17 Jun 2026 13:00:49 GMT 6
7.1.7-beta.1 160.47 KB Mon, 15 Jun 2026 17:28:37 GMT 5
7.1.6 156.55 KB Tue, 02 Jun 2026 16:35:35 GMT 4
7.1.6-beta.1 156.11 KB Tue, 02 Jun 2026 13:24:52 GMT 3
7.1.5-beta.2 156.34 KB Sat, 16 May 2026 12:15:37 GMT 5
7.1.5-beta 155.83 KB Wed, 01 Apr 2026 12:10:42 GMT 11
7.1.4 155.87 KB Sun, 29 Mar 2026 16:07:39 GMT 13
7.1.4-beta 155.89 KB Tue, 24 Mar 2026 12:10:43 GMT 18
7.1.3 155.65 KB Tue, 24 Mar 2026 08:01:03 GMT 11
7.1.2 154.2 KB Mon, 09 Mar 2026 21:49:02 GMT 11
7.1.1 152.61 KB Mon, 09 Mar 2026 19:22:05 GMT 11
7.1.0 141.87 KB Mon, 09 Mar 2026 15:09:15 GMT 12
7.1.0-beta.2 141.94 KB Fri, 06 Mar 2026 08:23:00 GMT 11
7.1.0-beta.1 136.6 KB Thu, 26 Feb 2026 20:30:45 GMT 14
7.0.6 141.71 KB Tue, 03 Mar 2026 13:52:39 GMT 17
7.0.5 136.26 KB Thu, 26 Feb 2026 20:33:55 GMT 9
7.0.4 136.07 KB Tue, 17 Feb 2026 17:08:59 GMT 14
7.0.4-beta.3 136.35 KB Sat, 14 Feb 2026 15:10:05 GMT 13
7.0.4-beta.2 136.32 KB Sat, 14 Feb 2026 14:49:36 GMT 12
7.0.4-beta.1 136.06 KB Sat, 14 Feb 2026 13:15:33 GMT 14
7.0.3 135.83 KB Sat, 14 Feb 2026 13:04:04 GMT 18
7.0.2 134.4 KB Tue, 23 Dec 2025 10:43:03 GMT 15
7.0.1 134.52 KB Mon, 08 Dec 2025 07:47:11 GMT 17
7.0.0 130.87 KB Sun, 07 Dec 2025 19:21:58 GMT 29
6.1.1 83.14 KB Mon, 01 Sep 2025 08:29:13 GMT 84
6.1.0 83.15 KB Mon, 01 Sep 2025 07:36:07 GMT 85
6.0.0 38.37 KB Sat, 23 Dec 2023 19:44:23 GMT 95
6.0.0-beta.3 38.37 KB Mon, 01 May 2023 13:55:43 GMT 83
6.0.0-beta.2 38.7 KB Sun, 12 Feb 2023 20:28:39 GMT 89
6.0.0-beta.1 39.05 KB Sat, 23 Jul 2022 20:03:41 GMT 100
5.7.0 43.32 KB Fri, 10 Jun 2022 10:38:09 GMT 87
5.6.0 43.32 KB Fri, 10 Jun 2022 10:24:11 GMT 87
5.5.0 43.38 KB Sun, 01 May 2022 19:40:08 GMT 87
5.4.0 43.58 KB Mon, 28 Mar 2022 18:35:16 GMT 96
5.3.0 43.57 KB Sun, 19 Sep 2021 15:22:18 GMT 86
5.2.0 43.48 KB Sat, 31 Jul 2021 14:50:34 GMT 92
5.1.0 43.46 KB Thu, 17 Jun 2021 15:59:54 GMT 96
5.1.0-rc.2 43.47 KB Thu, 03 Jun 2021 20:35:12 GMT 99
5.1.0-rc.1 42.49 KB Tue, 01 Jun 2021 08:14:50 GMT 91
5.0.0 41.65 KB Sun, 30 May 2021 09:25:09 GMT 94
5.0.0-rc.2 41.67 KB Tue, 18 May 2021 14:25:52 GMT 90
5.0.0-rc.1 41.64 KB Tue, 18 May 2021 10:35:39 GMT 87
4.3.0 28.73 KB Sun, 02 May 2021 18:37:25 GMT 98
4.3.0-rc.1 29.02 KB Thu, 25 Mar 2021 16:20:24 GMT 94
4.2.0 28.92 KB Sun, 21 Mar 2021 14:21:00 GMT 81
4.1.0 26.27 KB Thu, 18 Feb 2021 19:18:07 GMT 95
4.1.0-rc.1 26.28 KB Fri, 08 Jan 2021 14:04:28 GMT 93
4.0.0 23.81 KB Fri, 01 Jan 2021 18:15:58 GMT 89
4.0.0-rc.2 22.58 KB Sat, 18 Jul 2020 11:34:07 GMT 87
4.0.0-rc.1 22.91 KB Mon, 15 Jun 2020 07:44:40 GMT 107
3.2.0 22.43 KB Thu, 16 Jul 2020 08:55:46 GMT 94
3.1.1 21.06 KB Tue, 28 Apr 2020 19:50:38 GMT 91
3.1.0 21.08 KB Tue, 28 Apr 2020 19:44:12 GMT 81
3.0.0 21 KB Fri, 06 Mar 2020 18:33:53 GMT 101
3.0.0-rc.6 20.78 KB Wed, 05 Feb 2020 19:14:35 GMT 90
3.0.0-rc.5 20.83 KB Fri, 24 Jan 2020 16:14:36 GMT 102
3.0.0-rc.4 19.93 KB Sun, 29 Dec 2019 21:20:26 GMT 87
3.0.0-rc.3 18.63 KB Thu, 28 Nov 2019 20:13:09 GMT 92
3.0.0-rc.2 18.46 KB Sun, 13 Oct 2019 19:01:50 GMT 91
3.0.0-rc.1 18.29 KB Mon, 30 Sep 2019 21:32:44 GMT 83
3.0.0-beta.1 18.08 KB Thu, 25 Apr 2019 21:47:21 GMT 104
3.0.0-alpha.1 17.97 KB Tue, 23 Apr 2019 20:36:02 GMT 92
2.3.0 18.92 KB Thu, 14 Nov 2019 20:19:50 GMT 101
2.2.1 18.67 KB Thu, 14 Nov 2019 19:23:42 GMT 97
2.2.0 18.3 KB Wed, 28 Aug 2019 20:28:53 GMT 102
2.1.1 17.83 KB Thu, 25 Apr 2019 21:48:11 GMT 92
2.1.0 17.73 KB Mon, 08 Apr 2019 12:24:34 GMT 80
2.0.1 17.79 KB Mon, 08 Apr 2019 12:06:38 GMT 87
2.0.0 16.5 KB Wed, 13 Mar 2019 19:08:14 GMT 111
2.0.0-beta.5 16.29 KB Sun, 24 Feb 2019 07:31:07 GMT 91
2.0.0-beta.4 16.31 KB Wed, 13 Feb 2019 20:13:52 GMT 83
2.0.0-beta.3 16.36 KB Mon, 11 Feb 2019 20:23:30 GMT 93
2.0.0-beta.2 16.81 KB Mon, 21 Jan 2019 20:37:24 GMT 87
2.0.0-beta.1 16.76 KB Mon, 12 Nov 2018 20:40:04 GMT 101
1.2.0 16.09 KB Tue, 22 Jan 2019 07:33:31 GMT 85
1.1.0 16.1 KB Mon, 21 Jan 2019 22:00:43 GMT 95
1.0.0 16.5 KB Wed, 26 Sep 2018 20:08:53 GMT 107
1.0.0-rc.1 16.52 KB Fri, 21 Sep 2018 20:37:01 GMT 94
1.0.0-beta.3 16.5 KB Wed, 19 Sep 2018 19:48:11 GMT 101
1.0.0-beta.2 15.93 KB Mon, 10 Sep 2018 16:27:12 GMT 87
1.0.0-beta.1 14.27 KB Fri, 24 Aug 2018 17:32:30 GMT 88
0.8.2 14.05 KB Fri, 29 Jun 2018 09:29:45 GMT 84
0.8.1 14.02 KB Wed, 20 Jun 2018 23:33:00 GMT 82
0.8.0 13.96 KB Tue, 12 Jun 2018 22:26:34 GMT 101
0.8.0-beta.3 13.97 KB Tue, 12 Jun 2018 22:21:17 GMT 94
0.8.0-beta.2 13.83 KB Mon, 11 Jun 2018 10:57:57 GMT 81
0.8.0-beta.1 13.24 KB Fri, 11 May 2018 10:39:26 GMT 98
0.7.0 13.1 KB Fri, 11 May 2018 10:24:33 GMT 89
0.6.0 10.27 KB Wed, 04 Apr 2018 19:32:20 GMT 93
0.5.0 10.24 KB Fri, 30 Mar 2018 20:04:37 GMT 82
0.4.0 9.81 KB Thu, 29 Mar 2018 23:07:36 GMT 95
0.3.0 8.46 KB Thu, 29 Mar 2018 21:28:37 GMT 90
0.2.0 6.73 KB Sun, 25 Mar 2018 15:14:15 GMT 95
0.0.2 6.73 KB Fri, 23 Mar 2018 20:19:30 GMT 86