GitXplorerGitXplorer
a

better-ajv-errors

public
232 stars
44 forks
48 issues

Commits

List of commits on branch main.
Unverified
70356a517e452d774dbf5d480e1e8bf1d5d07388

chore(deps): update dependency jest to v28

rrenovate-bot committed 2 years ago
Unverified
58336aaa5be7e298864ecda3573f88a9ca271d2b

chore(deps): update github/codeql-action action to v2

rrenovate-bot committed 2 years ago
Unverified
619aee80cb013e151bc2f7e2163a67cc33048a19

chore(deps): update dependency flow-bin to ^0.176.0

rrenovate-bot committed 2 years ago
Unverified
43720f632b335827e47839ac91ab056104a89472

Version Packages

ggithub-actions[bot] committed 2 years ago
Unverified
7184b1e78e38ddaf890439f57820a3d3cc4388db

Remove unused imports

qqueengooborg committed 2 years ago
Unverified
3918d589c4ad58b610a324191a579cf7c8ccc12e

Add changeset

ttorifat committed 2 years ago

README

The README file for this repository.

better-ajv-errors

JSON Schema validation for Human 👨‍🎤

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

Installation

$ npm i better-ajv-errors
$ # Or
$ yarn add 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 'better-ajv-errors';
// const Ajv = require('ajv');
// const betterAjvErrors = require('better-ajv-errors').default;
// Or
// const { default: betterAjvErrors } = require('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.