
Security News
Axios Maintainer Confirms Social Engineering Attack Behind npm Compromise
Axios compromise traced to social engineering, showing how attacks on maintainers can bypass controls and expose the broader software supply chain.
json-validity
Advanced tools
Fast JSON validator build for simplicity
const {isValid} = require('json-validity')
const songSchema = {
published: 'number',
style: [ 'rock', 'jazz' ],
title: 'string',
}
const song = {
published: 1975,
style: 'rock',
title: 'In my time of dying',
}
isValid({input: song, schema: songSchema})
// => true

input - object to be validated
schema - schema object with rules
{ foo: val => val.length > 2 }
{ foo: 'string' }
{ foo: 'number' }
{ foo: 'boolean' }
{ foo: /[a-z]{1,3}/ }
{ foo: [ 'bar', 'baz', 1, null ] }
Valid object - { foo: 1 }
Valid object - { foo: 'baz' }
Valid object - { foo: null }
Note that you can also set single enum value expectation, such as { foo: ['bar'] }
We can nest schemas such as:
const fooSchema = {bar: 'string'}
const schema = {
foo: fooSchema,
bar: 'number'
}
const input = {
foo: {bar: 'You shook me'},
bar: 1
}
isValid({input, schema})
// => true
{ foo: 'array' }
{ foo: ['string'] }
Property is array of elements, with each element is validated against the single schema object.
Note, that if the schema is { foo: 'string' }, the object {foo: 'bar',baz: 1} is valid.
In other words, we can have aditional properties, without breaking the validation.
songSchema - { title: 'string' } { foo: [ songSchema ] }
const basicSchema = {
a: ['string']
}
const schema = {
b: [basicSchema],
c: {
d: {
e: 'boolean'
},
f: 'array'
},
g: ['foo','bar','baz']
}
const input = {
b: [
{
a: ['led', 'zeppelin']
}
],
c: {
d: {
e: true
},
f: []
},
g: 'foo'
}
isValid({input,schema}) // => true
FAQs
Fast and simple JSON validator
The npm package json-validity receives a total of 11 weekly downloads. As such, json-validity popularity was classified as not popular.
We found that json-validity demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
Axios compromise traced to social engineering, showing how attacks on maintainers can bypass controls and expose the broader software supply chain.

Security News
Node.js has paused its bug bounty program after funding ended, removing payouts for vulnerability reports but keeping its security process unchanged.

Security News
The Axios compromise shows how time-dependent dependency resolution makes exposure harder to detect and contain.