Repository is archived
No commit activity in last 3 years
No release in over 3 years
SchemaValidator
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

< 6, >= 4.2
~> 0.11
 Project Readme

SchemaValidator

Usage

Just define a json schema definition and assign it to any constant within the class definition:

# app/schemas/any_schema.rb

class AnySchema < Schema::Base
  SCHEMA_NAME = ::IceNine.deep_freeze(
    type: 'object', properties: {
      nested_blocks_attributes: {
        type: 'array', minItems: 1, items: {
          type: 'object', properties: {
            date: { type: 'string', format: 'date-time' },
            values: {
              type: 'object', properties: {
                attr_1: { type: 'array', items: { type: ['number', 'integer'] }, minItems: 5, maxItems: 5 },
                attr_2: { type: 'array', items: { type: ['number'] }, minItems: 4, maxItems: 4 },
                attr_3: { type: 'array', items: { type: ['integer'], minimum: 0, maximum: 1 }, minItems: 64, maxItems: 64 },
                attr_4: { type: 'array', items: { type: ['integer'] }, minItems: 4, maxItems: 4 },
              }
            }
          }
        }
      }
    }
  )
end

Then, you just need to call either validate, validate! or fully_validate:

AnySchema.validate! params_hash

Options

It's possible to have multiple schema definitions within the same class, the name must be specified in that case:

AnySchema.validate! params_hash, schema: 'OTHER_SCHEMA_NAME'

Other options are the one in use with the json-schema gem.

Default options already set are strict: true, parse_data: false, insert_defaults: true.

Since most schema definitions are static configurations, IceNine deep_freeze is recommended and included within the gemspec.

This project rocks and uses MIT-LICENSE.