GHM.Validator
3.3.1
See the version list below for details.
dotnet add package GHM.Validator --version 3.3.1
NuGet\Install-Package GHM.Validator -Version 3.3.1
<PackageReference Include="GHM.Validator" Version="3.3.1" />
paket add GHM.Validator --version 3.3.1
#r "nuget: GHM.Validator, 3.3.1"
// Install GHM.Validator as a Cake Addin #addin nuget:?package=GHM.Validator&version=3.3.1 // Install GHM.Validator as a Cake Tool #tool nuget:?package=GHM.Validator&version=3.3.1
<p align="center"> <img src="logo.png" alt="logo" width="200px"/> </p>
<h1 align="center"> GHM.Validator </h1>
GHM.Validator is a nuget package aims to validate data.
Install Package
.NET CLI
dotnet add package GHM.Validator
Package Manager
NuGet\Install-Package GHM.Validator
IServiceCollectionExtensions
To add transient interface IValidate
to implementate Validate
or IThrower
to implementate Thrower
, call extension method to your serviceCollection.
using GHM.Validator.Extensions;
var builder = WebApplication.CreateBuilder(args);
var services = builder.Services;
service.AddGhmValidator();
If you want to set a default exception for IThrower
, pass a Func<string, Exception> as a parameter to the AddGhmValidator
method.
using GHM.Validator.Extensions;
var builder = WebApplication.CreateBuilder(args);
var services = builder.Services;
service.AddGhmValidator((message) => new TestException(message));
Example
To validate request data
using GHM.Validator;
public Validation[] ValidateCreateUserRequest(CreateUserRequest request)
{
IValidate validate;
return new Validation[]
{
validate.IfNotNull(request.Name,"Name must not be null"),
validate.IfNotZero(request.Age,"Age must not be 0")
};
}
If error message is null, it will be passed a default message.
using GHM.Validator;
public Validation[] ValidateCreateUserRequest(CreateUserRequest request)
{
IValidate validate;
return new Validation[]
{
validate.IfNotNull(request.UserName), // Validated param: UserName. Value: Gustavo. ValidationName: IfNotNull
validate.IfNotZero(request.UserAge) // Error to validate param: UserAge. Value: 0. ValidationName: IfNotZero
};
}
You can set a errorType.
using GHM.Validator;
public Validation[] ValidateCreateUserRequest(CreateUserRequest request)
{
IValidate validate;
return new Validation[]
{
validate.IfNotNull(request.UserName).AsNotFound(), // validate.ErrorType = ErrorType.NotFound
validate.IfNotZero(request.UserAge).AsFailure() // validate.ErrorType = ErrorType.Failure
};
}
Throw Exception from validation if it's invalid.
using GHM.Validator;
public Validation[] ValidateCreateUserRequest(CreateUserRequest request)
{
IValidate validate;
var list = new ValidationList
{
validate.IfNotNull(request.Name,"Name must not be null"),
validate.IfNotZero(request.Age,"Age must not be 0")
};
list.ThrowErrorsWithMessage(" | ") //throw new ValidationException("Name must not be null | Age must not be 0").
return list;
}
To throw if request data is invalid
using GHM.Validator;
public bool ValidateCreateUserRequest(CreateUserRequest request)
{
IThrower thrower;
thrower.IfNull(request.Name,"Name must not be null");// if null, throw ArgumentException.
thrower.IfZero(request.Age,"Age must not be 0"); // if zero, throw ArgumentException.
return true;
}
Setting a Exception.
using GHM.Validator;
public bool ValidateCreateUserRequest(CreateUserRequest request)
{
IThrower thrower;
thrower.SetException((message) => new TestException(message))
thrower.IfNull(request.Name,"Name must not be null");
thrower.IfZero(request.Age,"Age must not be 0");
return true;
}
Classes
Validation
Validation is a object with properties(Message, IsValid).
using GHM.Validator;
var validationSuccess = Validation.Success("Successful message");
validationSuccess.Message; // "Successful message"
validationSuccess.IsValid; // true
var validationError = Validation.Error("Error message");
validationError.Message; // "Error message"
validationError.IsValid; // false
Result
Result is a object to return a value and/or validations
using GHM.Validator;
public Result<User> CreateUser(CreateUserRequest request)
{
IValidate validate;
ValidationList validations = new
{
validate.IfNotNull(request.Name,"Name must not be null"),
validate.IfNotZero(request.Age,"Age must not be 0")
};
if(validations.IsError)
{
return validations
}
User user = _userRepository.Create(request);
return new Result<User>(validations, user); // Return all validations and value
return user; // Return only value
}
Interfaces
IValidate
You can use it to return a validation result.
public interface IValidate
{
Validation IfTrue(bool condition, string message = null);
Validation IfFalse(bool condition, string message = null);
Validation IfNotDefault<T>(T obj, string message = null);
Validation IfNotNull(object? obj, string message = null);
Validation IfNull(object? obj, string message = null);
Validation IfEqual(object obj, object toCompare, string message = null);
Validation IfNotZero(int number, string message = null);
Validation IfNotZero(decimal number, string message = null);
Validation IfGreaterOrEqual(int number, int toCompare, string message = null);
Validation IfGreater(int number, int toCompare, string message = null);
Validation IfGreaterOrEqual(decimal number, decimal toCompare, string message = null);
Validation IfGreater(decimal number, decimal toCompare, string message = null);
Validation IfNotEmpty(string text, string message = null);
Validation IfParseToLong(string text, string message = null);
Validation IfNotEmpty<T>(IEnumerable<T> list, string message = null);
Validation IfOlder(DateTime date, DateTime toCompare, string message = null);
Validation IfOlderOrEqual(DateTime date, DateTime toCompare, string message = null);
}
IThrower
You can use it to throw exception.
public interface IThrower
{
void SetException(Func<string, Exception> exceptionThrower);
bool IfFalse(bool condition, string message = null);
bool IfTrue(bool condition, string message = null);
bool IfDefault<T>(T obj, string message = null);
bool IfNotNull(object? obj, string message = null);
bool IfNull(object? obj, string message = null);
bool IfNotEqual(object obj, object toCompare, string message = null);
bool IfZero(int number, string message = null);
bool IfZero(decimal number, string message = null);
bool IfGreaterOrEqual(int number, int toCompare, string message = null);
bool IfGreater(int number, int toCompare, string message = null);
bool IfGreaterOrEqual(decimal number, decimal toCompare, string message = null);
bool IfGreater(decimal number, decimal toCompare, string message = null);
bool IfEmpty(string text, string message = null);
bool IfNotParseToLong(string text, string message = null);
bool IfEmpty<T>(IEnumerable<T> list, string message = null);
bool IfOlder(DateTime date, DateTime toCompare, string message = null);
bool IfOlderOrEqual(DateTime date, DateTime toCompare, string message = null);
}
Star
if you enjoy, don't forget the ⭐ and install the package 😊.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. 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. |
-
net7.0
- Microsoft.Extensions.DependencyInjection (>= 7.0.0)
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 |
---|---|---|
5.0.0 | 122 | 8/7/2024 |
4.0.0 | 94 | 8/2/2024 |
3.5.0 | 120 | 6/1/2024 |
3.4.2 | 131 | 2/26/2024 |
3.4.1 | 133 | 2/24/2024 |
3.3.1 | 133 | 2/14/2024 |
3.2.1 | 125 | 2/6/2024 |
3.2.0 | 119 | 2/5/2024 |
3.1.0 | 117 | 2/2/2024 |
2.1.3 | 156 | 1/12/2024 |
2.1.2 | 123 | 1/12/2024 |
2.1.1 | 121 | 1/12/2024 |
2.1.0 | 118 | 1/12/2024 |
2.0.0 | 213 | 11/15/2023 |
1.0.0 | 145 | 10/7/2023 |