wxyz.Validator
1.0.4
The owner has unlisted this package.
This could mean that the package is deprecated, has security vulnerabilities or shouldn't be used anymore.
dotnet add package wxyz.Validator --version 1.0.4
NuGet\Install-Package wxyz.Validator -Version 1.0.4
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="wxyz.Validator" Version="1.0.4" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="wxyz.Validator" Version="1.0.4" />
<PackageReference Include="wxyz.Validator" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add wxyz.Validator --version 1.0.4
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: wxyz.Validator, 1.0.4"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package wxyz.Validator@1.0.4
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=wxyz.Validator&version=1.0.4
#tool nuget:?package=wxyz.Validator&version=1.0.4
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
wxyz-Validator
Yet another validator for C# data object
Flow:
// validate with new context
new Validator<V,T>(T value)
--> new ValidatorContext ctx
--> static cache[new V()]
--> void static Validator.Validate(value, ctx)
--> cache[V].Test(value, ctx)
--> onSuccess, onError
// validate without using the onSuccess, onError
ValidatorContext ctx; // handles the result, Disposable
static Validator<V,T>.Validate(T value, ValidatorContext ctx)
--> if !cache[V] then cache[new V()]
--> cache[V].Test(value, ctx);
ValidatorBase<T>.chain<V, X>(X value, ValidatorContext ctx)
--> Validator<V, X>.Validate(value, ctx);
Sample
class Person {
public string name { get; set; }
public int age { get; set; }
}
Validator
sealed class PersonValidator : ValidatorBase<Person> {
public override void Test(Person value, ValidatorContext context) {
// MUST be called before any assertion
use(value, context);
required(value.name, "name is required");
required(value.age, "age is required");
min(value.age, 18);
}
}
Using lambda in validation rule
public override void Test(Person value, ValidatorContext context) {
// MUST be called before any assertion
use(value, context);
...
assert(x => x.age > 0, "non-zero positive number only for parameter age");
assert(x => x.age >= 12 && x.age <= 18, "age must be in range 12 to 18");
}
Running validator
public static void main(String[] args) {
var info = new Person { name = "Juan Puruntong", age = "16" };
using(var result = new Validator<PersonValidator, Person>(info)) {
result.onSuccess(x => {
Console.WriteLine(x.name);
})
.onError((errors, x) => {
foreach(String message in errors) {
Console.WriteLine(message);
}
Console.WriteLine("Error(s):{0}", errors.Count);
});
}
}
Chaining validators
class Address {
public string country { get; set; }
public string province { get; set; }
}
sealed class AddressValidator : ValidatorBase<Address> {
public override void Test(Address value, ValidatorContext context) {
// MUST be called before any assertion
use(value, context);
required(value.country);
required(value.province);
}
}
Calling chain
class Person {
...
public Address address { get; set; }
}
sealed class PersonValidator : ValidatorBase<Person> {
public override void Test(Person value, ValidatorContext context) {
// MUST be called before any assertion
use(value, context);
...
required(value.address);
chain<AddressValidator, Address>(value.address);
}
}
Validator<V,T> runs in a single ValidatorContext to prevent validation loop when calling chain<V,T>(T value) in a ValidatorBase<T> child class.
Run validator using static Validator<V,T>.Validate
var ctx = new ValidatorContext();
Validator<PersonRules, Person>.Validate(info);
foreach(string message in ctx.GetErrors()) {
Console.WriteLine(message);
}
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. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.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.
Version | Downloads | Last Updated |
---|