MiniValidation 0.9.2
dotnet add package MiniValidation --version 0.9.2
NuGet\Install-Package MiniValidation -Version 0.9.2
<PackageReference Include="MiniValidation" Version="0.9.2" />
paket add MiniValidation --version 0.9.2
#r "nuget: MiniValidation, 0.9.2"
// Install MiniValidation as a Cake Addin #addin nuget:?package=MiniValidation&version=0.9.2 // Install MiniValidation as a Cake Tool #tool nuget:?package=MiniValidation&version=0.9.2
MiniValidation
A minimalistic validation library built atop the existing features in .NET's System.ComponentModel.DataAnnotations
namespace. Adds support for single-line validation calls and recursion with cycle detection.
Supports .NET Standard 2.0 compliant runtimes.
Installation
Install the library from NuGet:
❯ dotnet add package MiniValidation
ASP.NET Core 6+ Projects
If installing into an ASP.NET Core 6+ project, consider using the MinimalApis.Extensions package instead, which adds extensions specific to ASP.NET Core, including a validation endpoint filter for .NET 7 apps:
❯ dotnet add package MinimalApis.Extensions
Example usage
Validate an object
var widget = new Widget { Name = "" };
var isValid = MiniValidator.TryValidate(widget, out var errors);
class Widget
{
[Required, MinLength(3)]
public string Name { get; set; }
public override string ToString() => Name;
}
Use services from validators
var widget = new Widget { Name = "" };
// Get your serviceProvider from wherever makes sense
var serviceProvider = ...
var isValid = MiniValidator.TryValidate(widget, serviceProvider, out var errors);
class Widget : IValidatableObject
{
[Required, MinLength(3)]
public string Name { get; set; }
public override string ToString() => Name;
public IEnumerable<ValidationResult> Validate(ValidationContext validationContext)
{
var disallowedNamesService = validationContext.GetService(typeof(IDisallowedNamesService)) as IDisallowedNamesService;
if (disallowedNamesService is null)
{
throw new InvalidOperationException($"Validation of {nameof(Widget)} requires an {nameof(IDisallowedNamesService)} instance.");
}
if (disallowedNamesService.IsDisallowedName(Name))
{
yield return new($"Cannot name a widget '{Name}'.", new[] { nameof(Name) });
}
}
}
Console app
using System.ComponentModel.DataAnnotations;
using MiniValidation;
var title = args.Length > 0 ? args[0] : "";
var widgets = new List<Widget>
{
new Widget { Name = title },
new WidgetWithCustomValidation { Name = title }
};
foreach (var widget in widgets)
{
if (!MiniValidator.TryValidate(widget, out var errors))
{
Console.WriteLine($"{nameof(Widget)} has errors!");
foreach (var entry in errors)
{
Console.WriteLine($" {entry.Key}:");
foreach (var error in entry.Value)
{
Console.WriteLine($" - {error}");
}
}
}
else
{
Console.WriteLine($"{nameof(Widget)} '{widget}' is valid!");
}
}
class Widget
{
[Required, MinLength(3)]
public string Name { get; set; }
public override string ToString() => Name;
}
class WidgetWithCustomValidation : Widget, IValidatableObject
{
public IEnumerable<ValidationResult> Validate(ValidationContext validationContext)
{
if (string.Equals(Name, "Widget", StringComparison.OrdinalIgnoreCase))
{
yield return new($"Cannot name a widget '{Name}'.", new[] { nameof(Name) });
}
}
}
❯ widget.exe
Widget 'widget' is valid!
Widget has errors!
Name:
- Cannot name a widget 'widget'.
❯ widget.exe Ok
Widget has errors!
Name:
- The field Name must be a string or array type with a minimum length of '3'.
Widget has errors!
Name:
- The field Name must be a string or array type with a minimum length of '3'.
❯ widget.exe Widget
Widget 'Widget' is valid!
Widget has errors!
Name:
- Cannot name a widget 'Widget'.
❯ widget.exe MiniValidation
Widget 'MiniValidation' is valid!
Widget 'MiniValidation' is valid!
Web app (.NET 6)
using System.ComponentModel.DataAnnotations;
using MiniValidation;
var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();
app.MapGet("/", () => "Hello World");
app.MapGet("/widgets", () =>
new[] {
new Widget { Name = "Shinerizer" },
new Widget { Name = "Sparklizer" }
});
app.MapGet("/widgets/{name}", (string name) =>
new Widget { Name = name });
app.MapPost("/widgets", (Widget widget) =>
!MiniValidator.TryValidate(widget, out var errors)
? Results.ValidationProblem(errors)
: Results.Created($"/widgets/{widget.Name}", widget));
app.MapPost("/widgets/custom-validation", (WidgetWithCustomValidation widget) =>
!MiniValidator.TryValidate(widget, out var errors)
? Results.ValidationProblem(errors)
: Results.Created($"/widgets/{widget.Name}", widget));
app.Run();
class Widget
{
[Required, MinLength(3)]
public string? Name { get; set; }
public override string? ToString() => Name;
}
class WidgetWithCustomValidation : Widget, IValidatableObject
{
public IEnumerable<ValidationResult> Validate(ValidationContext validationContext)
{
if (string.Equals(Name, "Widget", StringComparison.OrdinalIgnoreCase))
{
yield return new($"Cannot name a widget '{Name}'.", new[] { nameof(Name) });
}
}
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. 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 was computed. 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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- System.ComponentModel.Annotations (>= 5.0.0)
-
net6.0
- No dependencies.
NuGet packages (18)
Showing the top 5 NuGet packages that depend on MiniValidation:
Package | Downloads |
---|---|
Indice.AspNetCore
Package Description |
|
MinimalApis.Extensions
A set of extensions and helpers for working with ASP.NET Core Minimal APIs. |
|
MinApiLib.Validation
Data annotations validation filter for Minimal API |
|
Hive.Abstractions
Base abstractions for Hive |
|
Wcz.Layout
Package Description |
GitHub repositories (4)
Showing the top 4 popular GitHub repositories that depend on MiniValidation:
Repository | Stars |
---|---|
davidfowl/TodoApp
Todo application with ASP.NET Core Blazor WASM, Minimal APIs and Authentication
|
|
exceptionless/Exceptionless
Exceptionless application
|
|
DamianEdwards/MinimalApis.Extensions
A set of extensions and helpers for working with ASP.NET Core Minimal APIs.
|
|
marcominerva/MinimalHelpers
A collection of helpers libraries for Minimal API projects.
|
Version | Downloads | Last updated |
---|---|---|
0.9.2 | 3,708 | 12/20/2024 |
0.9.1 | 175,080 | 4/22/2024 |
0.9.0 | 180,712 | 10/15/2023 |
0.8.0 | 278,710 | 6/22/2023 |
0.7.4 | 65,117 | 3/17/2023 |
0.7.3 | 1,132 | 3/14/2023 |
0.7.2 | 51,231 | 12/21/2022 |
0.7.1 | 1,132 | 12/20/2022 |
0.7.0 | 24,654 | 11/29/2022 |
0.6.0-pre.20220527.55 | 67,394 | 5/27/2022 |
0.5.1-pre.20220429.53 | 6,465 | 4/29/2022 |
0.5.0-pre.20220315.50 | 19,884 | 3/15/2022 |
0.4.2-pre.20220306.48 | 2,395 | 3/6/2022 |
0.4.1-pre.20220107.41 | 10,086 | 1/7/2022 |
0.4.0-pre.20211110.38 | 30,243 | 11/10/2021 |
0.3.0-pre.20210927201159.35 | 2,562 | 9/27/2021 |
0.2.0-pre.20210920234953.30 | 1,931 | 9/20/2021 |