Socket
Socket
Sign inDemoInstall

@sidvind/better-ajv-errors

Package Overview
Dependencies
13
Maintainers
1
Versions
17
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    @sidvind/better-ajv-errors

JSON Schema validation for Human


Version published
Weekly downloads
190K
increased by3.39%
Maintainers
1
Install size
524 kB
Created
Weekly downloads
 

Changelog

Source

2.1.3

Patch Changes

  • cb0c12f: fix issue with decorating json path for array elements

Readme

Source

better-ajv-errors

JSON Schema validation for Human 👨‍🎤

Main goal of this library is to provide relevant error messages like the following:

Fork

This fork removes the legacy build and thus drops dependencies such as core-js and @babel/runtime which is not needed on modern installations.

  • Node 12 and later supports the modern build and according to the release plan node 10 was EOL at 2021-04-30.
  • Earlier versions is already EOL and not supported. Anyone using it should update instead.

The following PRs from upstream are merged:

  • PR-85: fix: enumeration in anyOf
  • PR-67: fix(typings): Correct TypeScript type definition (superseeded by upstream fix)
  • PR-70: Drop legacy build and dependecy on polyfills (dropped in favour of esbuild)

The following PRs has been merged upstream:

Installation

$ npm i @sidvind/better-ajv-errors

Also make sure that you installed ajv package to validate data against JSON schemas.

Usage

First, you need to validate your payload with ajv. If it's invalid then you can pass validate.errors object into better-ajv-errors.

import Ajv from 'ajv';
import betterAjvErrors from '@sidvind/better-ajv-errors';
// const Ajv = require('ajv');
// const betterAjvErrors = require('@sidvind/better-ajv-errors').default;
// Or
// const { default: betterAjvErrors } = require('@sidvid/better-ajv-errors');

// You need to pass `{ jsonPointers: true }` for older versions of ajv
const ajv = new Ajv();

// Load schema and data
const schema = ...;
const data = ...;

const validate = ajv.compile(schema);
const valid = validate(data);

if (!valid) {
  const output = betterAjvErrors(schema, data, validate.errors);
  console.log(output);
}

API

betterAjvErrors(schema, data, errors, [options])

Returns formatted validation error to print in console. See options.format for further details.

schema

Type: Object

The JSON Schema you used for validation with ajv

data

Type: Object

The JSON payload you validate against using ajv

errors

Type: Array

Array of ajv validation errors

options

Type: Object

format

Type: string
Default: cli
Values: cli js

Use default cli output format if you want to print beautiful validation errors like following:

Or, use js if you are planning to use this with some API. Your output will look like following:

[
  {
    start: { line: 6, column: 15, offset: 70 },
    end: { line: 6, column: 26, offset: 81 },
    error:
      '/content/0/type should be equal to one of the allowed values: panel, paragraph, ...',
    suggestion: 'Did you mean paragraph?',
  },
];
indent

Type: number null
Default: null

If you have an unindented JSON payload and you want the error output indented.

This option have no effect when using the json option.

json

Type: string null
Default: null

Raw JSON payload used when formatting codeframe. Gives accurate line and column listings.

Keywords

FAQs

Last updated on 10 Dec 2023

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc