BeingValidated 0.0.4
dotnet add package BeingValidated --version 0.0.4
NuGet\Install-Package BeingValidated -Version 0.0.4
<PackageReference Include="BeingValidated" Version="0.0.4" />
<PackageVersion Include="BeingValidated" Version="0.0.4" />
<PackageReference Include="BeingValidated" />
paket add BeingValidated --version 0.0.4
#r "nuget: BeingValidated, 0.0.4"
#:package BeingValidated@0.0.4
#addin nuget:?package=BeingValidated&version=0.0.4
#tool nuget:?package=BeingValidated&version=0.0.4
BeingValidated
A small tool, mainly for input object (request model, etc.) validation, I personally wrote and used in business projects. Its main purpose is to have validation codes more uniformed, and can be also used to construct a main method running multiple minor methods.
It targets .NET Standard 2.0 .
Usage
To start validating with an IBeingValidated, use .StartValidate()
or .StartValidateElements()
.
For example, let's say we already defined a class GetUserRequest
, and receives it on an endpoint we're writing. We then can validate the input like this
GetUserRequest input = ...; // accepted from client
GetUserResponse response = new();
bool isValid = input.StartValidate()
.Validate(i => i.UserId > 0,
i => response.AddError($"ID ({i.UserId}) not valid!"))
.Validate(i => i.MustProvide != null,
_ => response.AddError("MustProvide must be provided!")
.IsValid();
There is also ValidateAsync()
for running async methods.
bool isValid = await input.StartValidate()
.Validate(i => i.UserId > 0,
i => response.AddError($"ID ({i.UserId}) not valid!"))
.ValidateAsync(async i => await dbContext.User.AnyAsync(u => u.Id == i.UserId),
i => response.AddError($"ID ({i.UserId}) not found!",
e => response.AddError($"DB Query failed: {e.Message}")
.IsValid();
A Validate()
, or ValidateAsync()
provides 3 parameters, listed in the order of examples above:
- Validation method
- OnFail - method to execute when validation failed (optional)
- OnException - method to execute when validation throws (optional)
Usage - enumerable
To validate an enumerable, you can either use the .StartValidate()
above to validate the emuerable object, or use .StartValidateElements()
to validate every element in it.
Let's say we defined a GetUsersRequest
, and there's a IEnumerable<int> IdList
in it.
GetUsersRequest input = ...; // accepted from client
GetUsersResponse response = new();
bool isValid = input.IdList.StartValidateElements()
.Validate(i => i > 0,
i => response.AddError($"ID ({i}) not valid!"))
.IsValid();
Say there are 5 integers in the list, and 3 of them are invalid - i > 0
will be called 5 times, and AddError()
will be called 3 times.
ValidateAsync()
also supports it.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.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
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Fixed missing documentations.
https://choosealicense.com/licenses/bsd-3-clause/