topolis/validator

yaml based schema validation for multidimensional arrays

1.2.0 2019-10-08 09:43 UTC

This package is not auto-updated.

Last update: 2025-01-21 14:56:30 UTC


README

A complex validator that applies a yaml based schema file to a multi dimensional array

Syntax

A schema is a hirarchical Yaml file. Each level, starting from the root of the file contains one of 3 different constructs.

Properties

Properties is an object with a list of named properties. Each property can then contain other constructs. The Yaml representation of an object construct is:

Options

  • type defines if the property contains one sub construct or an array of sub constructs. Default: single
  • conditionals a list of conditionals (need to contain a properties key if they are to replace the base object). Default: undefined
  • default The default value if nothing is found. Default: undefined (will simply remove the property)
  • required Defines if this property must be present. Default: false
  • filter If type is multiple, this filter will be usedto validate the array keys. Default: undefined
  • options If type is multiple, these are the options for the key filter. Default: []
  • properties The array of properties of this object. Default: []
  • errors individual status codes can be overriden with custom codes and messages for this one validation rule. Default: [] (See below=

Sample

properties:
    one:
        ...
    two:
        ...
    three:
        ...
required: true
default: {one: A}        

Listing

This defines a key value array. The difference to an object is that keys are not strictly defined but only need to pass a filter.

Options

  • conditionals a list of conditionals (need to contain a properties key if they are to replace the base object). Default: undefined
  • default The default value if nothing is found. Default: undefined (will simply remove the property)
  • required Defines if this property must be present. Default: false
  • min The required minimum number of array elements. Default: false
  • max The required maximum number of array elements. Default: false
  • key Needs to contain a Value construct with the filter to use for array keys. Default: undefined
  • value Needs to contain a construct for array items. Default: undefined

Sample

listing:
    required: true
    min: 2
    max: 10
    key:
        ...
    value:
        ...        

Value

This defines a singular value.

Options

  • filter The filter to use (@see Topolis/Filter). Default: Passthrough
  • options The options for this filter. Default: [] (Keep in mind that Validator sets the default type of filters to single)
  • strict Defines if a value is allowed to be sanitized if possible or not. Default: false
  • default The default value if nothing is found. Default: undefined (will simply remove the property)
  • required Defines if this property must be present. Default: false

Sample

filter: PlainExt
options: {characters: ".-_"}
required: true
default: Pustekuchen
        

Custom Errors

FOr each validation rule, a custom error can bespecified for individual status codes. Be carefull with custom codes though as there are certain rules expected from your validation results.

  • Positive/Negative following typical process exit codes, any positive code is considered a success. Any negative code is considered a failure
  • Severity The more negative a number is, the more dramatic is the error. Most calling programms expect correct values for invalid or sanitized results. Be carefull to not break your result code checks.

Default error codes

  • ERROR = -100 A critical execution or configuration error
  • INVALID = -11 The result did not pass the minimal required rules
  • SANITIZED = -2 The result has non-critical problems. The values causeing these problems could be adjusted automatically
  • INFO = -1 The result is completely valid but there are informational messages
  • VALID = 1 The result is completely valid

Sample

filter: PlainExt
options: {characters: ".-_"}
errors: 
    -2:
        code: -1
        message: This data could be sanitized but we think a info alone is enough
    -11:
        code: -192
        message: This very special check failed      

Open Tasks

  • BUG: Definition wrong in StatusManager (Can't reproduce. Where?)
  • FR: reference definitions in other files
  • FR: Auto incremental indexes in listings