Dosaic.Plugins.Validations.AttributeValidation
1.0.30
dotnet add package Dosaic.Plugins.Validations.AttributeValidation --version 1.0.30
NuGet\Install-Package Dosaic.Plugins.Validations.AttributeValidation -Version 1.0.30
<PackageReference Include="Dosaic.Plugins.Validations.AttributeValidation" Version="1.0.30" />
paket add Dosaic.Plugins.Validations.AttributeValidation --version 1.0.30
#r "nuget: Dosaic.Plugins.Validations.AttributeValidation, 1.0.30"
// Install Dosaic.Plugins.Validations.AttributeValidation as a Cake Addin #addin nuget:?package=Dosaic.Plugins.Validations.AttributeValidation&version=1.0.30 // Install Dosaic.Plugins.Validations.AttributeValidation as a Cake Tool #tool nuget:?package=Dosaic.Plugins.Validations.AttributeValidation&version=1.0.30
Dosaic.Plugins.Validations.AttributeValidation
Dosaic.Plugins.Validations.AttributeValidation is a plugin
that allows other Dosaic components
to validate object using attributes
.
Installation
To install the nuget package follow these steps:
dotnet add package Dosaic.Plugins.Validations.AttributeValidation
or add as package reference to your .csproj
<PackageReference Include="Dosaic.Plugins.Validations.AttributeValidation" Version="" />
Appsettings.yml
You do not need to configure anything, because the implementation resolver, does this automatically at startup.
Usage
The validator is auto-registered using the Plugin technology. You can use it by adding the Validations
attribute to your model and inject the IValidator in your usage.
However, there are following Validations attibutes:
- Required
- Expression
- Array
- Length
- MinLength
- MaxLength
- Bool
- True
- False
- Date
- Before
- After
- Age
- MinAge
- MaxAge
- Int
- Range
- Min
- Max
- Positive
- Negative
- String
- Length
- MinLength
- MaxLength
- Url
- Regex
Example:
```csharp
internal class DbModel {
[Validations.Required]
public string Id {get;set;}
[Validations.String.MinLength(5), Validations.String.MaxLength(10), Validations.String.Regex(@"^[a-zA-Z]+$")]
public string LongName {get;set;}
[Validations.Expression("Value % 2 == 0")]
public int SomeNumber {get;set;}
}
// USAGE:
IServiceProvider sp;
var validator = sp.GetRequiredService<IValidator>();
var dbModel = new DbModel { Id = "1", LongName = "LongName", SomeNumber = 2 };
var result = await validator.ValidateAsync(dbModel);
Console.WriteLine(result.IsValid); // true
var failModel = new DbModel { Id = "", LongName = "..", SomeNumber = 3 };
var result = await validator.ValidateAsync(dbModel);
Console.WriteLine(result.IsValid); // false
Console.WriteLine(result.Errors); // List of errors
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net9.0 is compatible. 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. |
-
net9.0
- Dosaic.Hosting.Abstractions (>= 1.0.30)
- Dosaic.Plugins.Validations.Abstractions (>= 1.0.30)
- DynamicExpresso.Core (>= 2.17.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.