-
Notifications
You must be signed in to change notification settings - Fork 16
Home
To participate in enterprise business process, employees, customers and partners need to interact with data stored in various enterprise applications – whether providing information or retrieving it. These stored data are typically structured data or semi-structured data that must correspond to specific business rules or validation rules.
Validation engine offers a way how to define business rules of the product, the contract, or to define validation rules of the forms that captures this data.
//data structure
interface IPerson{
FirstName:string;
LastName:string;
}
//create new validator for object with structure<IPerson>
var personValidator = new Validation.AbstractValidator<IPerson>();
//basic validators
var required =new Validation.RequiredValidator();
var maxLength = new Validation.MaxLengthValidator(15);
//assigned validators to property
personValidator.RuleFor("FirstName", required);
personValidator.RuleFor("FirstName",maxLength);
//assigned validators to property
personValidator.RuleFor("LastName", required);
personValidator.RuleFor("LastName",maxLength);
//concrete validator var concreteValidator = personValidator.CreateRule("Data"); //sample data with errors var data = { FirstName : "", LastName: "Toooooooooooooooooooooooooooooooo long name" }; //validate var result = concreteValidator.Validate(data); //verify by return result expect(result.HasErrors).to.equal(true); if (result.HasErrors) console.log(result.ErrorMessage); //verify by concrete validator properties expect(concreteValidator.ValidationResult.HasErrors).to.equal(true); if (concreteValidator.ValidationResult.HasErrors) console.log(concreteValidator.ValidationResult.ErrorMessage); //validator properties enables to check specific rule errors expect(concreteValidator.Rules["FirstName"].ValidationFailures["required"].HasError).to.equal(true); expect(concreteValidator.Rules["FirstName"].ValidationFailures["maxlength"].HasError).to.equal(false); expect(concreteValidator.Rules["LastName"].ValidationFailures["required"].HasError).to.equal(false); expect(concreteValidator.Rules["LastName"].ValidationFailures["maxlength"].HasError).to.equal(true);
The main benefit is that validation engine is not tight to HTML DOM or any other UI framework. This validation engine is UI agnostic and that is why it can be used as an independent representation of business rules of a product, contract, etc. It can be easily reused by different types of applications, libraries.
- Client - server validation of business rules for an product.
- UI application uses validation engine to enforce all validation rules with quick answer to client.
- Server non-UI application uses the same business rules to enforce validity of business rules of the product once again (according to rule no client is trusted).
- Validation of business rules of automatically generated products, contracts, etc.
- Server non-UI application can automatically generate the product or the contract. Validation engine enforce validation of business rules of the product, the contract, etc.
- Forms application which uses business rules to capture structured or semi-structured data.
- There is no dependencies on HTML DOM.
- It enables to decorate custom objects and its properties with validation rules.
- It supports composition of validation rules, that enables to validate custom object with nested structures.
- It is ease to create your own custom validators.
- It supports asynchronous validation rules (uses promises).
- It supports assigning validation rules to collection-based structures - arrays and lists.
- It supports localization of error messages with TranslateArgs.
- It deploys as AMD, CommonJS or plain script module pattern.
- It offers basic build-in constrains validators. Other custom validators can be find in extensible repository of custom validators.
- Custom property validator
- Custom object validator
- with property validation rules (sync and async)
- with collection-valued, array-valued and generally Iterable fields and properties
- with shared validation rules
- Composite object validator
The validation is not dependend on HTML DOM. The only depedency is on ECMAScript.
Temporary there is dependency on the underscore javacript library.
There can be other dependencies on other javascript libraries for custom validation rules found in repository of custom validators.
Before using any custom validator found in repository, check the api for the custom validator for possible dependencies. E.g. DataCompareValidator requires underscore + moment javascript libraries.
The Property validator is designed to validate objects against constraints. They are assertions that a condition is true.
- Required
- EqualTo
- Url
- MaxLength,MinLength,RangeLength
- Pattern
- Number
- Digits, SignedDigits
- Max,Min,Range
- Step
- Date
- DateISO
- DateCompare
- Currency
- CreditCard
- Luhn
- Contains
It enables to localization of constrains messages. See the list of available localization messages in i18n directory.
Localization is enabled by default. It is enough to add reference to specific localization files. For Czech Republic localization add reference to dist/i18n/messages_cs.js to html page where you want to use CZ messages.
//data structure
interface IPerson{
FirstName:string;
LastName:string;
}
//create new validator for object with structure var personValidator = new Validation.AbstractValidator(); //basic validators var required =new Validation.RequiredValidator(); var maxLength = new Validation.MaxLengthValidator(15); //assigned validators to property personValidator.RuleFor("FirstName", required); personValidator.RuleFor("FirstName",maxLength); //assigned validators to property personValidator.RuleFor("LastName", required); personValidator.RuleFor("LastName",maxLength);
//concrete validator var concreteValidator = personValidator.CreateRule("Data"); //sample data with errors var data = { FirstName : "", LastName: "Toooooooooooooooooooooooooooooooo long name" }; //validate var result = concreteValidator.Validate(data); //verify by return result expect(result.HasErrors).to.equal(true); if (result.HasErrors) console.log(result.ErrorMessage); //verify by concrete validator properties expect(concreteValidator.ValidationResult.HasErrors).to.equal(true); if (concreteValidator.ValidationResult.HasErrors) console.log(concreteValidator.ValidationResult.ErrorMessage); //validator properties enables to check specific rule errors expect(concreteValidator.Rules["FirstName"].ValidationFailures["required"].HasError).to.equal(true); expect(concreteValidator.Rules["FirstName"].ValidationFailures["maxlength"].HasError).to.equal(false); expect(concreteValidator.Rules["LastName"].ValidationFailures["required"].HasError).to.equal(false); expect(concreteValidator.Rules["LastName"].ValidationFailures["maxlength"].HasError).to.equal(true);
The main benefit is that validation engine is not tight to HTML DOM or any other UI framework. This validation engine is UI agnostic and that is why it can be used as an independent representation of business rules of a product, contract, etc. It can be easily reused by different types of applications, libraries.
- Client - server validation of business rules for an product.
- UI application uses validation engine to enforce all validation rules with quick answer to client.
- Server non-UI application uses the same business rules to enforce validity of business rules of the product once again (according to rule no client is trusted).
- Validation of business rules of automatically generated products, contracts, etc.
- Server non-UI application can automatically generate the product or the contract. Validation engine enforce validation of business rules of the product, the contract, etc.
- Forms application which uses business rules to capture structured or semi-structured data.
- There is no dependencies on HTML DOM.
- It enables to decorate custom objects and its properties with validation rules.
- It supports composition of validation rules, that enables to validate custom object with nested structures.
- It is ease to create your own custom validators.
- It supports asynchronous validation rules (uses promises).
- It supports assigning validation rules to collection-based structures - arrays and lists.
- It supports localization of error messages with TranslateArgs.
- It deploys as AMD, CommonJS or plain script module pattern.
- It offers basic build-in constrains validators. Other custom validators can be find in extensible repository of custom validators.
- Custom property validator
- Custom object validator
- with property validation rules (sync and async)
- with collection-valued, array-valued and generally Iterable fields and properties
- with shared validation rules
- Composite object validator
The validation is not dependend on HTML DOM. The only depedency is on ECMAScript.
Temporary there is dependency on the underscore javacript library.
There can be other dependencies on other javascript libraries for custom validation rules found in repository of custom validators.
Before using any custom validator found in repository, check the api for the custom validator for possible dependencies. E.g. DataCompareValidator requires underscore + moment javascript libraries.
The Property validator is designed to validate objects against constraints. They are assertions that a condition is true.
- Required
- EqualTo
- Url
- MaxLength,MinLength,RangeLength
- Pattern
- Number
- Digits, SignedDigits
- Max,Min,Range
- Step
- Date
- DateISO
- DateCompare
- Currency
- CreditCard
- Luhn
- Contains
It enables to localization of constrains messages. See the list of available localization messages in i18n directory.
Localization is enabled by default. It is enough to add reference to specific localization files. For Czech Republic localization add reference to dist/i18n/messages_cs.js to html page where you want to use CZ messages.
...