2021-05-08 05:39:21 -07:00
declare var ajv : {
2017-12-15 10:56:14 -08:00
( options? : ajv.Options ) : ajv . Ajv ;
2021-05-08 05:39:21 -07:00
new ( options? : ajv.Options ) : ajv . Ajv ;
ValidationError : typeof AjvErrors . ValidationError ;
MissingRefError : typeof AjvErrors . MissingRefError ;
$dataMetaSchema : object ;
}
declare namespace AjvErrors {
class ValidationError extends Error {
constructor ( errors : Array < ajv.ErrorObject > ) ;
message : string ;
errors : Array < ajv.ErrorObject > ;
ajv : true ;
validation : true ;
}
class MissingRefError extends Error {
constructor ( baseId : string , ref : string , message? : string ) ;
static message : ( baseId : string , ref : string ) = > string ;
message : string ;
missingRef : string ;
missingSchema : string ;
}
2017-12-15 10:56:14 -08:00
}
declare namespace ajv {
2021-05-08 05:39:21 -07:00
type ValidationError = AjvErrors . ValidationError ;
type MissingRefError = AjvErrors . MissingRefError ;
2017-12-15 10:56:14 -08:00
interface Ajv {
/ * *
* Validate data using schema
* Schema will be compiled and cached ( using serialized JSON as key , [ fast - json - stable - stringify ] ( https : //github.com/epoberezkin/fast-json-stable-stringify) is used to serialize by default).
2021-05-08 05:39:21 -07:00
* @param { string | object | Boolean } schemaKeyRef key , ref or schema object
2017-12-15 10:56:14 -08:00
* @param { Any } data to be validated
* @return { Boolean } validation result . Errors from the last validation will be available in ` ajv.errors ` ( and also in compiled schema : ` schema.errors ` ) .
* /
2021-05-08 05:39:21 -07:00
validate ( schemaKeyRef : object | string | boolean , data : any ) : boolean | PromiseLike < any > ;
2017-12-15 10:56:14 -08:00
/ * *
* Create validating function for passed schema .
2021-05-08 05:39:21 -07:00
* @param { object | Boolean } schema schema object
2017-12-15 10:56:14 -08:00
* @return { Function } validating function
* /
2021-05-08 05:39:21 -07:00
compile ( schema : object | boolean ) : ValidateFunction ;
2017-12-15 10:56:14 -08:00
/ * *
* Creates validating function for passed schema with asynchronous loading of missing schemas .
* ` loadSchema ` option should be a function that accepts schema uri and node - style callback .
* @this Ajv
2021-05-08 05:39:21 -07:00
* @param { object | Boolean } schema schema object
2017-12-15 10:56:14 -08:00
* @param { Boolean } meta optional true to compile meta - schema ; this parameter can be skipped
* @param { Function } callback optional node - style callback , it is always called with 2 parameters : error ( or null ) and validating function .
2021-05-08 05:39:21 -07:00
* @return { PromiseLike < ValidateFunction > } validating function
2017-12-15 10:56:14 -08:00
* /
2021-05-08 05:39:21 -07:00
compileAsync ( schema : object | boolean , meta? : Boolean , callback ? : ( err : Error , validate : ValidateFunction ) = > any ) : PromiseLike < ValidateFunction > ;
2017-12-15 10:56:14 -08:00
/ * *
* Adds schema to the instance .
2021-05-08 05:39:21 -07:00
* @param { object | Array } schema schema or array of schemas . If array is passed , ` key ` and other parameters will be ignored .
* @param { string } key Optional schema key . Can be passed to ` validate ` method instead of schema object or id / ref . One schema per instance can have empty ` id ` and ` key ` .
2017-12-15 10:56:14 -08:00
* @return { Ajv } this for method chaining
* /
2021-05-08 05:39:21 -07:00
addSchema ( schema : Array < object > | object , key? : string ) : Ajv ;
2017-12-15 10:56:14 -08:00
/ * *
* Add schema that will be used to validate other schemas
* options in META_IGNORE_OPTIONS are alway set to false
2021-05-08 05:39:21 -07:00
* @param { object } schema schema object
* @param { string } key optional schema key
2017-12-15 10:56:14 -08:00
* @return { Ajv } this for method chaining
* /
2021-05-08 05:39:21 -07:00
addMetaSchema ( schema : object , key? : string ) : Ajv ;
2017-12-15 10:56:14 -08:00
/ * *
* Validate schema
2021-05-08 05:39:21 -07:00
* @param { object | Boolean } schema schema to validate
2017-12-15 10:56:14 -08:00
* @return { Boolean } true if schema is valid
* /
2021-05-08 05:39:21 -07:00
validateSchema ( schema : object | boolean ) : boolean ;
2017-12-15 10:56:14 -08:00
/ * *
* Get compiled schema from the instance by ` key ` or ` ref ` .
2021-05-08 05:39:21 -07:00
* @param { string } keyRef ` key ` that was passed to ` addSchema ` or full schema reference ( ` schema.id ` or resolved id ) .
* @return { Function } schema validating function ( with property ` schema ` ) . Returns undefined if keyRef can ' t be resolved to an existing schema .
2017-12-15 10:56:14 -08:00
* /
2021-05-08 05:39:21 -07:00
getSchema ( keyRef : string ) : ValidateFunction | undefined ;
2017-12-15 10:56:14 -08:00
/ * *
* Remove cached schema ( s ) .
* If no parameter is passed all schemas but meta - schemas are removed .
* If RegExp is passed all schemas with key / id matching pattern but meta - schemas are removed .
* Even if schema is referenced by other schemas it still can be removed as other schemas have local references .
2021-05-08 05:39:21 -07:00
* @param { string | object | RegExp | Boolean } schemaKeyRef key , ref , pattern to match key / ref or schema object
2017-12-15 10:56:14 -08:00
* @return { Ajv } this for method chaining
* /
2021-05-08 05:39:21 -07:00
removeSchema ( schemaKeyRef? : object | string | RegExp | boolean ) : Ajv ;
2017-12-15 10:56:14 -08:00
/ * *
* Add custom format
2021-05-08 05:39:21 -07:00
* @param { string } name format name
* @param { string | RegExp | Function } format string is converted to RegExp ; function should return boolean ( true when valid )
2017-12-15 10:56:14 -08:00
* @return { Ajv } this for method chaining
* /
addFormat ( name : string , format : FormatValidator | FormatDefinition ) : Ajv ;
/ * *
* Define custom keyword
* @this Ajv
2021-05-08 05:39:21 -07:00
* @param { string } keyword custom keyword , should be a valid identifier , should be different from all standard , custom and macro keywords .
* @param { object } definition keyword definition object with properties ` type ` ( type ( s ) which the keyword applies to ) , ` validate ` or ` compile ` .
2017-12-15 10:56:14 -08:00
* @return { Ajv } this for method chaining
* /
addKeyword ( keyword : string , definition : KeywordDefinition ) : Ajv ;
/ * *
* Get keyword definition
* @this Ajv
2021-05-08 05:39:21 -07:00
* @param { string } keyword pre - defined or custom keyword .
* @return { object | Boolean } custom keyword definition , ` true ` if it is a predefined keyword , ` false ` otherwise .
2017-12-15 10:56:14 -08:00
* /
2021-05-08 05:39:21 -07:00
getKeyword ( keyword : string ) : object | boolean ;
2017-12-15 10:56:14 -08:00
/ * *
* Remove keyword
* @this Ajv
2021-05-08 05:39:21 -07:00
* @param { string } keyword pre - defined or custom keyword .
2017-12-15 10:56:14 -08:00
* @return { Ajv } this for method chaining
* /
removeKeyword ( keyword : string ) : Ajv ;
/ * *
2021-05-08 05:39:21 -07:00
* Validate keyword
* @this Ajv
* @param { object } definition keyword definition object
* @param { boolean } throwError true to throw exception if definition is invalid
* @return { boolean } validation result
* /
validateKeyword ( definition : KeywordDefinition , throwError : boolean ) : boolean ;
/ * *
2017-12-15 10:56:14 -08:00
* Convert array of error message objects to string
2021-05-08 05:39:21 -07:00
* @param { Array < object > } errors optional array of validation errors , if not passed errors from the instance are used .
* @param { object } options optional options with properties ` separator ` and ` dataVar ` .
* @return { string } human readable string with all errors descriptions
2017-12-15 10:56:14 -08:00
* /
2021-05-08 05:39:21 -07:00
errorsText ( errors? : Array < ErrorObject > | null , options? : ErrorsTextOptions ) : string ;
errors? : Array < ErrorObject > | null ;
_opts : Options ;
2017-12-15 10:56:14 -08:00
}
2021-05-08 05:39:21 -07:00
interface CustomLogger {
log ( . . . args : any [ ] ) : any ;
warn ( . . . args : any [ ] ) : any ;
error ( . . . args : any [ ] ) : any ;
2017-12-15 10:56:14 -08:00
}
interface ValidateFunction {
(
data : any ,
dataPath? : string ,
2021-05-08 05:39:21 -07:00
parentData? : object | Array < any > ,
2017-12-15 10:56:14 -08:00
parentDataProperty? : string | number ,
2021-05-08 05:39:21 -07:00
rootData? : object | Array < any >
) : boolean | PromiseLike < any > ;
schema? : object | boolean ;
2017-12-15 10:56:14 -08:00
errors? : null | Array < ErrorObject > ;
2021-05-08 05:39:21 -07:00
refs? : object ;
2017-12-15 10:56:14 -08:00
refVal? : Array < any > ;
2021-05-08 05:39:21 -07:00
root? : ValidateFunction | object ;
2017-12-15 10:56:14 -08:00
$async? : true ;
2021-05-08 05:39:21 -07:00
source? : object ;
2017-12-15 10:56:14 -08:00
}
interface Options {
$data? : boolean ;
allErrors? : boolean ;
verbose? : boolean ;
jsonPointers? : boolean ;
uniqueItems? : boolean ;
unicode? : boolean ;
2021-05-08 05:39:21 -07:00
format? : false | string ;
formats? : object ;
keywords? : object ;
2017-12-15 10:56:14 -08:00
unknownFormats? : true | string [ ] | 'ignore' ;
2021-05-08 05:39:21 -07:00
schemas? : Array < object > | object ;
schemaId ? : '$id' | 'id' | 'auto' ;
2017-12-15 10:56:14 -08:00
missingRefs? : true | 'ignore' | 'fail' ;
extendRefs? : true | 'ignore' | 'fail' ;
2021-05-08 05:39:21 -07:00
loadSchema ? : ( uri : string , cb ? : ( err : Error , schema : object ) = > void ) = > PromiseLike < object | boolean > ;
2017-12-15 10:56:14 -08:00
removeAdditional? : boolean | 'all' | 'failing' ;
2021-05-08 05:39:21 -07:00
useDefaults? : boolean | 'empty' | 'shared' ;
2017-12-15 10:56:14 -08:00
coerceTypes? : boolean | 'array' ;
2021-05-08 05:39:21 -07:00
strictDefaults? : boolean | 'log' ;
strictKeywords? : boolean | 'log' ;
strictNumbers? : boolean ;
2017-12-15 10:56:14 -08:00
async ? : boolean | string ;
transpile? : string | ( ( code : string ) = > string ) ;
2021-05-08 05:39:21 -07:00
meta? : boolean | object ;
2017-12-15 10:56:14 -08:00
validateSchema? : boolean | 'log' ;
addUsedSchema? : boolean ;
inlineRefs? : boolean | number ;
passContext? : boolean ;
loopRequired? : number ;
ownProperties? : boolean ;
multipleOfPrecision? : boolean | number ;
errorDataPath? : string ,
messages? : boolean ;
sourceCode? : boolean ;
2021-05-08 05:39:21 -07:00
processCode ? : ( code : string , schema : object ) = > string ;
cache? : object ;
logger? : CustomLogger | false ;
nullable? : boolean ;
serialize ? : ( ( schema : object | boolean ) = > any ) | false ;
2017-12-15 10:56:14 -08:00
}
2021-05-08 05:39:21 -07:00
type FormatValidator = string | RegExp | ( ( data : string ) = > boolean | PromiseLike < any > ) ;
type NumberFormatValidator = ( ( data : number ) = > boolean | PromiseLike < any > ) ;
interface NumberFormatDefinition {
type : "number" ,
validate : NumberFormatValidator ;
compare ? : ( data1 : number , data2 : number ) = > number ;
async ? : boolean ;
}
2017-12-15 10:56:14 -08:00
2021-05-08 05:39:21 -07:00
interface StringFormatDefinition {
type ? : "string" ,
2017-12-15 10:56:14 -08:00
validate : FormatValidator ;
2021-05-08 05:39:21 -07:00
compare ? : ( data1 : string , data2 : string ) = > number ;
2017-12-15 10:56:14 -08:00
async ? : boolean ;
}
2021-05-08 05:39:21 -07:00
type FormatDefinition = NumberFormatDefinition | StringFormatDefinition ;
2017-12-15 10:56:14 -08:00
interface KeywordDefinition {
type ? : string | Array < string > ;
async ? : boolean ;
$data? : boolean ;
errors? : boolean | string ;
2021-05-08 05:39:21 -07:00
metaSchema? : object ;
2017-12-15 10:56:14 -08:00
// schema: false makes validate not to expect schema (ValidateFunction)
schema? : boolean ;
2021-05-08 05:39:21 -07:00
statements? : boolean ;
dependencies? : Array < string > ;
2017-12-15 10:56:14 -08:00
modifying? : boolean ;
valid? : boolean ;
// one and only one of the following properties should be present
validate? : SchemaValidateFunction | ValidateFunction ;
2021-05-08 05:39:21 -07:00
compile ? : ( schema : any , parentSchema : object , it : CompilationContext ) = > ValidateFunction ;
macro ? : ( schema : any , parentSchema : object , it : CompilationContext ) = > object | boolean ;
inline ? : ( it : CompilationContext , keyword : string , schema : any , parentSchema : object ) = > string ;
}
interface CompilationContext {
level : number ;
dataLevel : number ;
dataPathArr : string [ ] ;
schema : any ;
schemaPath : string ;
baseId : string ;
async : boolean ;
opts : Options ;
formats : {
[ index : string ] : FormatDefinition | undefined ;
} ;
keywords : {
[ index : string ] : KeywordDefinition | undefined ;
} ;
compositeRule : boolean ;
validate : ( schema : object ) = > boolean ;
util : {
copy ( obj : any , target? : any ) : any ;
toHash ( source : string [ ] ) : { [ index : string ] : true | undefined } ;
equal ( obj : any , target : any ) : boolean ;
getProperty ( str : string ) : string ;
schemaHasRules ( schema : object , rules : any ) : string ;
escapeQuotes ( str : string ) : string ;
toQuotedString ( str : string ) : string ;
getData ( jsonPointer : string , dataLevel : number , paths : string [ ] ) : string ;
escapeJsonPointer ( str : string ) : string ;
unescapeJsonPointer ( str : string ) : string ;
escapeFragment ( str : string ) : string ;
unescapeFragment ( str : string ) : string ;
} ;
self : Ajv ;
2017-12-15 10:56:14 -08:00
}
interface SchemaValidateFunction {
(
schema : any ,
data : any ,
2021-05-08 05:39:21 -07:00
parentSchema? : object ,
2017-12-15 10:56:14 -08:00
dataPath? : string ,
2021-05-08 05:39:21 -07:00
parentData? : object | Array < any > ,
2017-12-15 10:56:14 -08:00
parentDataProperty? : string | number ,
2021-05-08 05:39:21 -07:00
rootData? : object | Array < any >
) : boolean | PromiseLike < any > ;
2017-12-15 10:56:14 -08:00
errors? : Array < ErrorObject > ;
}
interface ErrorsTextOptions {
separator? : string ;
dataVar? : string ;
}
interface ErrorObject {
keyword : string ;
dataPath : string ;
schemaPath : string ;
params : ErrorParameters ;
// Added to validation errors of propertyNames keyword schema
propertyName? : string ;
// Excluded if messages set to false.
message? : string ;
// These are added with the `verbose` option.
schema? : any ;
2021-05-08 05:39:21 -07:00
parentSchema? : object ;
2017-12-15 10:56:14 -08:00
data? : any ;
}
type ErrorParameters = RefParams | LimitParams | AdditionalPropertiesParams |
2021-05-08 05:39:21 -07:00
DependenciesParams | FormatParams | ComparisonParams |
MultipleOfParams | PatternParams | RequiredParams |
TypeParams | UniqueItemsParams | CustomParams |
PatternRequiredParams | PropertyNamesParams |
IfParams | SwitchParams | NoParams | EnumParams ;
2017-12-15 10:56:14 -08:00
interface RefParams {
ref : string ;
}
interface LimitParams {
limit : number ;
}
interface AdditionalPropertiesParams {
additionalProperty : string ;
}
interface DependenciesParams {
property : string ;
missingProperty : string ;
depsCount : number ;
deps : string ;
}
interface FormatParams {
format : string
}
interface ComparisonParams {
comparison : string ;
limit : number | string ;
exclusive : boolean ;
}
interface MultipleOfParams {
multipleOf : number ;
}
interface PatternParams {
pattern : string ;
}
interface RequiredParams {
missingProperty : string ;
}
interface TypeParams {
type : string ;
}
interface UniqueItemsParams {
i : number ;
j : number ;
}
interface CustomParams {
keyword : string ;
}
interface PatternRequiredParams {
missingPattern : string ;
}
interface PropertyNamesParams {
propertyName : string ;
}
2021-05-08 05:39:21 -07:00
interface IfParams {
failingKeyword : string ;
}
2017-12-15 10:56:14 -08:00
interface SwitchParams {
caseIndex : number ;
}
2021-05-08 05:39:21 -07:00
interface NoParams { }
2017-12-15 10:56:14 -08:00
interface EnumParams {
allowedValues : Array < any > ;
}
}
export = ajv ;