![]() |
VOOZH | about |
dotnet add package MinApiLib.Validation --version 10.0.0
NuGet\Install-Package MinApiLib.Validation -Version 10.0.0
<PackageReference Include="MinApiLib.Validation" Version="10.0.0" />
<PackageVersion Include="MinApiLib.Validation" Version="10.0.0" />Directory.Packages.props
<PackageReference Include="MinApiLib.Validation" />Project file
paket add MinApiLib.Validation --version 10.0.0
#r "nuget: MinApiLib.Validation, 10.0.0"
#:package MinApiLib.Validation@10.0.0
#addin nuget:?package=MinApiLib.Validation&version=10.0.0Install as a Cake Addin
#tool nuget:?package=MinApiLib.Validation&version=10.0.0Install as a Cake Tool
This package contains extensions to use data annotations in your endpoints. It uses the MiniValidation library.
You can install this package using the NuGet package manager:
Install-Package MinApiLib.Validation
Or using the .NET CLI:
dotnet add package MinApiLib.Validation
To use the validation, you can use the WithValidation extension method:
global using MinApiLib.Validation;
Now configure the validation filter in your endpoint:
public record struct Request(
[FromBody] RequestBody Body
);
public class RequestBody
{
[Required, StringLength(150, MinimumLength = 3)]
public string Name { get; set; }
[Required]
public string City { get; set; }
[Required]
public string Country { get; set; }
}
public record CreateThing() : PostEndpoint<Request>("things")
{
protected override RouteHandlerBuilder Configure(RouteHandlerBuilder builder)
=> builder
.Produces<Response>(StatusCodes.Status201Created)
.WithName("CreateThings")
.WithTags("things")
.WithValidation(); // invokes .ProducesValidationError()
protected override async Task<IResult> OnHandleAsync(Request request, CancellationToken cancellationToken)
{
// async stuff
return Results.Created($"/things/{created.Id}", created);
}
}
It will validate the request body and return a 400 status code response if the validation fails:
$ curl -X POST -H "Content-Type: application/json" -d '{"name":"John Doe"}' "http://localhost:5000/things"
{"City":["The City field is required."],"Country":["The Country field is required."]}%
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net8.0 net8.0 is compatible. net8.0-android net8.0-android was computed. net8.0-browser net8.0-browser was computed. net8.0-ios net8.0-ios was computed. net8.0-maccatalyst net8.0-maccatalyst was computed. net8.0-macos net8.0-macos was computed. net8.0-tvos net8.0-tvos was computed. net8.0-windows net8.0-windows was computed. net9.0 net9.0 is compatible. net9.0-android net9.0-android was computed. net9.0-browser net9.0-browser was computed. net9.0-ios net9.0-ios was computed. net9.0-maccatalyst net9.0-maccatalyst was computed. net9.0-macos net9.0-macos was computed. net9.0-tvos net9.0-tvos was computed. net9.0-windows net9.0-windows was computed. net10.0 net10.0 is compatible. net10.0-android net10.0-android was computed. net10.0-browser net10.0-browser was computed. net10.0-ios net10.0-ios was computed. net10.0-maccatalyst net10.0-maccatalyst was computed. net10.0-macos net10.0-macos was computed. net10.0-tvos net10.0-tvos was computed. net10.0-windows net10.0-windows was computed. |
This package is not used by any NuGet packages.
This package is not used by any popular GitHub repositories.