This is a modified version of enjoi to roughly support the 'extends' keyword from older JSON Schema Draft versions below 4. It should not really be used for anything, but was made for a very specific need on one of our projects. This version adds very limited and untested support for 'extends' and for refs of other files.
Converts a JSON schema to a Joi schema for object validation.
enjoi
is built against json-schema v4, but does not support all of json-schema (yet).
Here is a list of some missing keyword support still being worked on:
not
format
object:patternProperties
object:additionalProperties
(supported as a boolean, not supported as a schema).array:items
(supports as single schema, not supported as array of schemas).array:additionalItems
enjoi(schema [, options])
schema
- a JSON schema.options
- an (optional) object of additional options such assubSchemas
and customtypes
.subSchemas
- an (optional) object with keys representing schema ids, and values representing schemas.types
- an (optional) object with keys representing type names and values representing a Joi schema.
Example:
var Joi = require('joi');
var Enjoi = require('enjoi');
var schema = Enjoi({
'title': 'Example Schema',
'type': 'object',
'properties': {
'firstName': {
'type': 'string'
},
'lastName': {
'type': 'string'
},
'age': {
'description': 'Age in years',
'type': 'integer',
'minimum': 0
}
},
'required': ['firstName', 'lastName']
});
Joi.validate({firstName: 'John', lastName: 'Doe', age: 45}, schema, function (error, value) {
error && console.log(error);
});
Can also call validate
directly on the created schema.
schema.validate({firstName: 'John', lastName: 'Doe', age: 45}, function (error, value) {
error && console.log(error);
});
Example:
var schema = Enjoi({
'title': 'Example Schema',
'type': 'object',
'properties': {
'A': {
'$ref': 'sub#/something'
}
}
}, {
subSchemas: {
'sub': {
'something': {
'type': 'string'
}
}
}
});
var schema = Enjoi({
type: 'file'
}, {
types: {
file: Enjoi({
type: 'object',
properties: {
file: {
type: 'string'
},
consumes: {
type: 'string',
pattern: /multipart\/form-data/
}
}
})
}
});
schema.validate({file: 'data', consumes: 'multipart/form-data'}, function (error, value) {
error && console.log(error);
});