@rjsf/validator-ajv8 5.5.2 → 5.6.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/validator-ajv8.cjs.development.js +13 -175
- package/dist/validator-ajv8.cjs.development.js.map +1 -1
- package/dist/validator-ajv8.cjs.production.min.js +1 -1
- package/dist/validator-ajv8.cjs.production.min.js.map +1 -1
- package/dist/validator-ajv8.esm.js +13 -172
- package/dist/validator-ajv8.esm.js.map +1 -1
- package/dist/validator-ajv8.umd.development.js +16 -175
- package/dist/validator-ajv8.umd.development.js.map +1 -1
- package/dist/validator-ajv8.umd.production.min.js +1 -1
- package/dist/validator-ajv8.umd.production.min.js.map +1 -1
- package/package.json +12 -11
|
@@ -2,20 +2,14 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var toPath = require('lodash/toPath');
|
|
6
|
-
var isPlainObject = require('lodash/isPlainObject');
|
|
7
|
-
var clone = require('lodash/clone');
|
|
8
|
-
var utils = require('@rjsf/utils');
|
|
9
5
|
var get = require('lodash/get');
|
|
6
|
+
var utils = require('@rjsf/utils');
|
|
10
7
|
var Ajv = require('ajv');
|
|
11
8
|
var addFormats = require('ajv-formats');
|
|
12
9
|
var isObject = require('lodash/isObject');
|
|
13
10
|
|
|
14
11
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
15
12
|
|
|
16
|
-
var toPath__default = /*#__PURE__*/_interopDefaultLegacy(toPath);
|
|
17
|
-
var isPlainObject__default = /*#__PURE__*/_interopDefaultLegacy(isPlainObject);
|
|
18
|
-
var clone__default = /*#__PURE__*/_interopDefaultLegacy(clone);
|
|
19
13
|
var get__default = /*#__PURE__*/_interopDefaultLegacy(get);
|
|
20
14
|
var Ajv__default = /*#__PURE__*/_interopDefaultLegacy(Ajv);
|
|
21
15
|
var addFormats__default = /*#__PURE__*/_interopDefaultLegacy(addFormats);
|
|
@@ -104,7 +98,6 @@ function createAjvInstance(additionalMetaSchemas, customFormats, ajvOptionsOverr
|
|
|
104
98
|
}
|
|
105
99
|
|
|
106
100
|
var _excluded = ["instancePath", "keyword", "params", "schemaPath", "parentSchema"];
|
|
107
|
-
var ROOT_SCHEMA_PREFIX = '__rjsf_rootSchema';
|
|
108
101
|
/** `ValidatorType` implementation that uses the AJV 8 validation mechanism.
|
|
109
102
|
*/
|
|
110
103
|
var AJV8Validator = /*#__PURE__*/function () {
|
|
@@ -132,135 +125,25 @@ var AJV8Validator = /*#__PURE__*/function () {
|
|
|
132
125
|
this.ajv = createAjvInstance(additionalMetaSchemas, customFormats, ajvOptionsOverrides, ajvFormatOptions, AjvClass);
|
|
133
126
|
this.localizer = localizer;
|
|
134
127
|
}
|
|
135
|
-
/** Transforms a ajv validation errors list:
|
|
136
|
-
* [
|
|
137
|
-
* {property: '.level1.level2[2].level3', message: 'err a'},
|
|
138
|
-
* {property: '.level1.level2[2].level3', message: 'err b'},
|
|
139
|
-
* {property: '.level1.level2[4].level3', message: 'err b'},
|
|
140
|
-
* ]
|
|
141
|
-
* Into an error tree:
|
|
142
|
-
* {
|
|
143
|
-
* level1: {
|
|
144
|
-
* level2: {
|
|
145
|
-
* 2: {level3: {errors: ['err a', 'err b']}},
|
|
146
|
-
* 4: {level3: {errors: ['err b']}},
|
|
147
|
-
* }
|
|
148
|
-
* }
|
|
149
|
-
* };
|
|
150
|
-
*
|
|
151
|
-
* @param errors - The list of RJSFValidationError objects
|
|
152
|
-
* @private
|
|
153
|
-
*/
|
|
154
|
-
var _proto = AJV8Validator.prototype;
|
|
155
|
-
_proto.toErrorSchema = function toErrorSchema(errors) {
|
|
156
|
-
var builder = new utils.ErrorSchemaBuilder();
|
|
157
|
-
if (errors.length) {
|
|
158
|
-
errors.forEach(function (error) {
|
|
159
|
-
var property = error.property,
|
|
160
|
-
message = error.message;
|
|
161
|
-
var path = toPath__default["default"](property);
|
|
162
|
-
// If the property is at the root (.level1) then toPath creates
|
|
163
|
-
// an empty array element at the first index. Remove it.
|
|
164
|
-
if (path.length > 0 && path[0] === '') {
|
|
165
|
-
path.splice(0, 1);
|
|
166
|
-
}
|
|
167
|
-
if (message) {
|
|
168
|
-
builder.addErrors(message, path);
|
|
169
|
-
}
|
|
170
|
-
});
|
|
171
|
-
}
|
|
172
|
-
return builder.ErrorSchema;
|
|
173
|
-
}
|
|
174
128
|
/** Converts an `errorSchema` into a list of `RJSFValidationErrors`
|
|
175
129
|
*
|
|
176
130
|
* @param errorSchema - The `ErrorSchema` instance to convert
|
|
177
131
|
* @param [fieldPath=[]] - The current field path, defaults to [] if not specified
|
|
178
|
-
|
|
132
|
+
* @deprecated - Use the `toErrorList()` function provided by `@rjsf/utils` instead. This function will be removed in
|
|
133
|
+
* the next major release.
|
|
134
|
+
*/
|
|
135
|
+
var _proto = AJV8Validator.prototype;
|
|
179
136
|
_proto.toErrorList = function toErrorList(errorSchema, fieldPath) {
|
|
180
|
-
var _this = this;
|
|
181
137
|
if (fieldPath === void 0) {
|
|
182
138
|
fieldPath = [];
|
|
183
139
|
}
|
|
184
|
-
|
|
185
|
-
return [];
|
|
186
|
-
}
|
|
187
|
-
var errorList = [];
|
|
188
|
-
if (utils.ERRORS_KEY in errorSchema) {
|
|
189
|
-
errorList = errorList.concat(errorSchema[utils.ERRORS_KEY].map(function (message) {
|
|
190
|
-
var property = "." + fieldPath.join('.');
|
|
191
|
-
return {
|
|
192
|
-
property: property,
|
|
193
|
-
message: message,
|
|
194
|
-
stack: property + " " + message
|
|
195
|
-
};
|
|
196
|
-
}));
|
|
197
|
-
}
|
|
198
|
-
return Object.keys(errorSchema).reduce(function (acc, key) {
|
|
199
|
-
if (key !== utils.ERRORS_KEY) {
|
|
200
|
-
var childSchema = errorSchema[key];
|
|
201
|
-
if (isPlainObject__default["default"](childSchema)) {
|
|
202
|
-
acc = acc.concat(_this.toErrorList(childSchema, [].concat(fieldPath, [key])));
|
|
203
|
-
}
|
|
204
|
-
}
|
|
205
|
-
return acc;
|
|
206
|
-
}, errorList);
|
|
207
|
-
}
|
|
208
|
-
/** Given a `formData` object, recursively creates a `FormValidation` error handling structure around it
|
|
209
|
-
*
|
|
210
|
-
* @param formData - The form data around which the error handler is created
|
|
211
|
-
* @private
|
|
212
|
-
*/;
|
|
213
|
-
_proto.createErrorHandler = function createErrorHandler(formData) {
|
|
214
|
-
var _this2 = this;
|
|
215
|
-
var handler = {
|
|
216
|
-
// We store the list of errors for this node in a property named __errors
|
|
217
|
-
// to avoid name collision with a possible sub schema field named
|
|
218
|
-
// 'errors' (see `utils.toErrorSchema`).
|
|
219
|
-
__errors: [],
|
|
220
|
-
addError: function addError(message) {
|
|
221
|
-
this.__errors.push(message);
|
|
222
|
-
}
|
|
223
|
-
};
|
|
224
|
-
if (Array.isArray(formData)) {
|
|
225
|
-
return formData.reduce(function (acc, value, key) {
|
|
226
|
-
var _extends2;
|
|
227
|
-
return _extends({}, acc, (_extends2 = {}, _extends2[key] = _this2.createErrorHandler(value), _extends2));
|
|
228
|
-
}, handler);
|
|
229
|
-
}
|
|
230
|
-
if (isPlainObject__default["default"](formData)) {
|
|
231
|
-
var formObject = formData;
|
|
232
|
-
return Object.keys(formObject).reduce(function (acc, key) {
|
|
233
|
-
var _extends3;
|
|
234
|
-
return _extends({}, acc, (_extends3 = {}, _extends3[key] = _this2.createErrorHandler(formObject[key]), _extends3));
|
|
235
|
-
}, handler);
|
|
236
|
-
}
|
|
237
|
-
return handler;
|
|
238
|
-
}
|
|
239
|
-
/** Unwraps the `errorHandler` structure into the associated `ErrorSchema`, stripping the `addError` functions from it
|
|
240
|
-
*
|
|
241
|
-
* @param errorHandler - The `FormValidation` error handling structure
|
|
242
|
-
* @private
|
|
243
|
-
*/;
|
|
244
|
-
_proto.unwrapErrorHandler = function unwrapErrorHandler(errorHandler) {
|
|
245
|
-
var _this3 = this;
|
|
246
|
-
return Object.keys(errorHandler).reduce(function (acc, key) {
|
|
247
|
-
if (key === 'addError') {
|
|
248
|
-
return acc;
|
|
249
|
-
} else {
|
|
250
|
-
var _extends5;
|
|
251
|
-
var childSchema = errorHandler[key];
|
|
252
|
-
if (isPlainObject__default["default"](childSchema)) {
|
|
253
|
-
var _extends4;
|
|
254
|
-
return _extends({}, acc, (_extends4 = {}, _extends4[key] = _this3.unwrapErrorHandler(childSchema), _extends4));
|
|
255
|
-
}
|
|
256
|
-
return _extends({}, acc, (_extends5 = {}, _extends5[key] = childSchema, _extends5));
|
|
257
|
-
}
|
|
258
|
-
}, {});
|
|
140
|
+
return utils.toErrorList(errorSchema, fieldPath);
|
|
259
141
|
}
|
|
260
142
|
/** Transforming the error output from ajv to format used by @rjsf/utils.
|
|
261
143
|
* At some point, components should be updated to support ajv.
|
|
262
144
|
*
|
|
263
145
|
* @param errors - The list of AJV errors to convert to `RJSFValidationErrors`
|
|
146
|
+
* @param [uiSchema] - An optional uiSchema that is passed to `transformErrors` and `customValidate`
|
|
264
147
|
* @protected
|
|
265
148
|
*/;
|
|
266
149
|
_proto.transformRJSFValidationErrors = function transformRJSFValidationErrors(errors, uiSchema) {
|
|
@@ -370,7 +253,7 @@ var AJV8Validator = /*#__PURE__*/function () {
|
|
|
370
253
|
if (typeof transformErrors === 'function') {
|
|
371
254
|
errors = transformErrors(errors, uiSchema);
|
|
372
255
|
}
|
|
373
|
-
var errorSchema =
|
|
256
|
+
var errorSchema = utils.toErrorSchema(errors);
|
|
374
257
|
if (invalidSchemaError) {
|
|
375
258
|
errorSchema = _extends({}, errorSchema, {
|
|
376
259
|
$schema: {
|
|
@@ -386,43 +269,13 @@ var AJV8Validator = /*#__PURE__*/function () {
|
|
|
386
269
|
}
|
|
387
270
|
// Include form data with undefined values, which is required for custom validation.
|
|
388
271
|
var newFormData = utils.getDefaultFormState(this, schema, formData, schema, true);
|
|
389
|
-
var errorHandler = customValidate(newFormData,
|
|
390
|
-
var userErrorSchema =
|
|
391
|
-
return utils.
|
|
272
|
+
var errorHandler = customValidate(newFormData, utils.createErrorHandler(newFormData), uiSchema);
|
|
273
|
+
var userErrorSchema = utils.unwrapErrorHandler(errorHandler);
|
|
274
|
+
return utils.validationDataMerge({
|
|
392
275
|
errors: errors,
|
|
393
276
|
errorSchema: errorSchema
|
|
394
277
|
}, userErrorSchema);
|
|
395
278
|
}
|
|
396
|
-
/** Takes a `node` object and transforms any contained `$ref` node variables with a prefix, recursively calling
|
|
397
|
-
* `withIdRefPrefix` for any other elements.
|
|
398
|
-
*
|
|
399
|
-
* @param node - The object node to which a ROOT_SCHEMA_PREFIX is added when a REF_KEY is part of it
|
|
400
|
-
* @private
|
|
401
|
-
*/;
|
|
402
|
-
_proto.withIdRefPrefixObject = function withIdRefPrefixObject(node) {
|
|
403
|
-
for (var key in node) {
|
|
404
|
-
var realObj = node;
|
|
405
|
-
var value = realObj[key];
|
|
406
|
-
if (key === utils.REF_KEY && typeof value === 'string' && value.startsWith('#')) {
|
|
407
|
-
realObj[key] = ROOT_SCHEMA_PREFIX + value;
|
|
408
|
-
} else {
|
|
409
|
-
realObj[key] = this.withIdRefPrefix(value);
|
|
410
|
-
}
|
|
411
|
-
}
|
|
412
|
-
return node;
|
|
413
|
-
}
|
|
414
|
-
/** Takes a `node` object list and transforms any contained `$ref` node variables with a prefix, recursively calling
|
|
415
|
-
* `withIdRefPrefix` for any other elements.
|
|
416
|
-
*
|
|
417
|
-
* @param node - The list of object nodes to which a ROOT_SCHEMA_PREFIX is added when a REF_KEY is part of it
|
|
418
|
-
* @private
|
|
419
|
-
*/;
|
|
420
|
-
_proto.withIdRefPrefixArray = function withIdRefPrefixArray(node) {
|
|
421
|
-
for (var i = 0; i < node.length; i++) {
|
|
422
|
-
node[i] = this.withIdRefPrefix(node[i]);
|
|
423
|
-
}
|
|
424
|
-
return node;
|
|
425
|
-
}
|
|
426
279
|
/** Validates data against a schema, returning true if the data is valid, or
|
|
427
280
|
* false otherwise. If the schema is invalid, then this function will return
|
|
428
281
|
* false.
|
|
@@ -433,7 +286,7 @@ var AJV8Validator = /*#__PURE__*/function () {
|
|
|
433
286
|
*/;
|
|
434
287
|
_proto.isValid = function isValid(schema, formData, rootSchema) {
|
|
435
288
|
var _rootSchema$$id;
|
|
436
|
-
var rootSchemaId = (_rootSchema$$id = rootSchema['$id']) != null ? _rootSchema$$id : ROOT_SCHEMA_PREFIX;
|
|
289
|
+
var rootSchemaId = (_rootSchema$$id = rootSchema['$id']) != null ? _rootSchema$$id : utils.ROOT_SCHEMA_PREFIX;
|
|
437
290
|
try {
|
|
438
291
|
// add the rootSchema ROOT_SCHEMA_PREFIX as id.
|
|
439
292
|
// then rewrite the schema ref's to point to the rootSchema
|
|
@@ -442,7 +295,7 @@ var AJV8Validator = /*#__PURE__*/function () {
|
|
|
442
295
|
if (this.ajv.getSchema(rootSchemaId) === undefined) {
|
|
443
296
|
this.ajv.addSchema(rootSchema, rootSchemaId);
|
|
444
297
|
}
|
|
445
|
-
var schemaWithIdRefPrefix =
|
|
298
|
+
var schemaWithIdRefPrefix = utils.withIdRefPrefix(schema);
|
|
446
299
|
var compiledValidator;
|
|
447
300
|
if (schemaWithIdRefPrefix['$id']) {
|
|
448
301
|
compiledValidator = this.ajv.getSchema(schemaWithIdRefPrefix['$id']);
|
|
@@ -460,21 +313,6 @@ var AJV8Validator = /*#__PURE__*/function () {
|
|
|
460
313
|
// make sure we remove the rootSchema from the global ajv instance
|
|
461
314
|
this.ajv.removeSchema(rootSchemaId);
|
|
462
315
|
}
|
|
463
|
-
}
|
|
464
|
-
/** Recursively prefixes all $ref's in a schema with `ROOT_SCHEMA_PREFIX`
|
|
465
|
-
* This is used in isValid to make references to the rootSchema
|
|
466
|
-
*
|
|
467
|
-
* @param schemaNode - The object node to which a ROOT_SCHEMA_PREFIX is added when a REF_KEY is part of it
|
|
468
|
-
* @protected
|
|
469
|
-
*/;
|
|
470
|
-
_proto.withIdRefPrefix = function withIdRefPrefix(schemaNode) {
|
|
471
|
-
if (Array.isArray(schemaNode)) {
|
|
472
|
-
return this.withIdRefPrefixArray([].concat(schemaNode));
|
|
473
|
-
}
|
|
474
|
-
if (isPlainObject__default["default"](schemaNode)) {
|
|
475
|
-
return this.withIdRefPrefixObject(clone__default["default"](schemaNode));
|
|
476
|
-
}
|
|
477
|
-
return schemaNode;
|
|
478
316
|
};
|
|
479
317
|
return AJV8Validator;
|
|
480
318
|
}();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validator-ajv8.cjs.development.js","sources":["../src/createAjvInstance.ts","../src/validator.ts","../src/customizeValidator.ts","../src/index.ts"],"sourcesContent":["import Ajv, { Options } from 'ajv';\nimport addFormats, { FormatsPluginOptions } from 'ajv-formats';\nimport isObject from 'lodash/isObject';\n\nimport { CustomValidatorOptionsType } from './types';\nimport { ADDITIONAL_PROPERTY_FLAG, RJSF_ADDITONAL_PROPERTIES_FLAG } from '@rjsf/utils';\n\nexport const AJV_CONFIG: Options = {\n allErrors: true,\n multipleOfPrecision: 8,\n strict: false,\n verbose: true,\n} as const;\nexport const COLOR_FORMAT_REGEX =\n /^(#?([0-9A-Fa-f]{3}){1,2}\\b|aqua|black|blue|fuchsia|gray|green|lime|maroon|navy|olive|orange|purple|red|silver|teal|white|yellow|(rgb\\(\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*,\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*,\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*\\))|(rgb\\(\\s*(\\d?\\d%|100%)+\\s*,\\s*(\\d?\\d%|100%)+\\s*,\\s*(\\d?\\d%|100%)+\\s*\\)))$/;\nexport const DATA_URL_FORMAT_REGEX = /^data:([a-z]+\\/[a-z0-9-+.]+)?;(?:name=(.*);)?base64,(.*)$/;\n\n/** Creates an Ajv version 8 implementation object with standard support for the 'color` and `data-url` custom formats.\n * If `additionalMetaSchemas` are provided then the Ajv instance is modified to add each of the meta schemas in the\n * list. If `customFormats` are provided then those additional formats are added to the list of supported formats. If\n * `ajvOptionsOverrides` are provided then they are spread on top of the default `AJV_CONFIG` options when constructing\n * the `Ajv` instance. With Ajv v8, the JSON Schema formats are not provided by default, but can be plugged in. By\n * default, all formats from the `ajv-formats` library are added. To disable this capability, set the `ajvFormatOptions`\n * parameter to `false`. Additionally, you can configure the `ajv-formats` by providing a custom set of\n * [format options](https://github.com/ajv-validator/ajv-formats) to the `ajvFormatOptions` parameter.\n *\n * @param [additionalMetaSchemas] - The list of additional meta schemas that the validator can access\n * @param [customFormats] - The set of additional custom formats that the validator will support\n * @param [ajvOptionsOverrides={}] - The set of validator config override options\n * @param [ajvFormatOptions] - The `ajv-format` options to use when adding formats to `ajv`; pass `false` to disable it\n * @param [AjvClass] - The `Ajv` class to use when creating the validator instance\n */\nexport default function createAjvInstance(\n additionalMetaSchemas?: CustomValidatorOptionsType['additionalMetaSchemas'],\n customFormats?: CustomValidatorOptionsType['customFormats'],\n ajvOptionsOverrides: CustomValidatorOptionsType['ajvOptionsOverrides'] = {},\n ajvFormatOptions?: FormatsPluginOptions | false,\n AjvClass: typeof Ajv = Ajv\n) {\n const ajv = new AjvClass({ ...AJV_CONFIG, ...ajvOptionsOverrides });\n if (ajvFormatOptions) {\n addFormats(ajv, ajvFormatOptions);\n } else if (ajvFormatOptions !== false) {\n addFormats(ajv);\n }\n\n // add custom formats\n ajv.addFormat('data-url', DATA_URL_FORMAT_REGEX);\n ajv.addFormat('color', COLOR_FORMAT_REGEX);\n\n // Add RJSF-specific additional properties keywords so Ajv doesn't report errors if strict is enabled.\n ajv.addKeyword(ADDITIONAL_PROPERTY_FLAG);\n ajv.addKeyword(RJSF_ADDITONAL_PROPERTIES_FLAG);\n\n // add more schemas to validate against\n if (Array.isArray(additionalMetaSchemas)) {\n ajv.addMetaSchema(additionalMetaSchemas);\n }\n\n // add more custom formats to validate against\n if (isObject(customFormats)) {\n Object.keys(customFormats).forEach((formatName) => {\n ajv.addFormat(formatName, customFormats[formatName]);\n });\n }\n\n return ajv;\n}\n","import Ajv, { ErrorObject, ValidateFunction } from 'ajv';\nimport toPath from 'lodash/toPath';\nimport isPlainObject from 'lodash/isPlainObject';\nimport clone from 'lodash/clone';\nimport {\n CustomValidator,\n ERRORS_KEY,\n ErrorSchema,\n ErrorSchemaBuilder,\n ErrorTransformer,\n FieldValidation,\n FormContextType,\n FormValidation,\n GenericObjectType,\n getDefaultFormState,\n mergeValidationData,\n REF_KEY,\n RJSFSchema,\n RJSFValidationError,\n StrictRJSFSchema,\n UiSchema,\n ValidationData,\n ValidatorType,\n PROPERTIES_KEY,\n getUiOptions,\n} from '@rjsf/utils';\nimport get from 'lodash/get';\n\nimport { CustomValidatorOptionsType, Localizer } from './types';\nimport createAjvInstance from './createAjvInstance';\n\nconst ROOT_SCHEMA_PREFIX = '__rjsf_rootSchema';\n\n/** `ValidatorType` implementation that uses the AJV 8 validation mechanism.\n */\nexport default class AJV8Validator<T = any, S extends StrictRJSFSchema = RJSFSchema, F extends FormContextType = any>\n implements ValidatorType<T, S, F>\n{\n /** The AJV instance to use for all validations\n *\n * @private\n */\n private ajv: Ajv;\n\n /** The Localizer function to use for localizing Ajv errors\n *\n * @private\n */\n readonly localizer?: Localizer;\n\n /** Constructs an `AJV8Validator` instance using the `options`\n *\n * @param options - The `CustomValidatorOptionsType` options that are used to create the AJV instance\n * @param [localizer] - If provided, is used to localize a list of Ajv `ErrorObject`s\n */\n constructor(options: CustomValidatorOptionsType, localizer?: Localizer) {\n const { additionalMetaSchemas, customFormats, ajvOptionsOverrides, ajvFormatOptions, AjvClass } = options;\n this.ajv = createAjvInstance(additionalMetaSchemas, customFormats, ajvOptionsOverrides, ajvFormatOptions, AjvClass);\n this.localizer = localizer;\n }\n\n /** Transforms a ajv validation errors list:\n * [\n * {property: '.level1.level2[2].level3', message: 'err a'},\n * {property: '.level1.level2[2].level3', message: 'err b'},\n * {property: '.level1.level2[4].level3', message: 'err b'},\n * ]\n * Into an error tree:\n * {\n * level1: {\n * level2: {\n * 2: {level3: {errors: ['err a', 'err b']}},\n * 4: {level3: {errors: ['err b']}},\n * }\n * }\n * };\n *\n * @param errors - The list of RJSFValidationError objects\n * @private\n */\n private toErrorSchema(errors: RJSFValidationError[]): ErrorSchema<T> {\n const builder = new ErrorSchemaBuilder<T>();\n if (errors.length) {\n errors.forEach((error) => {\n const { property, message } = error;\n const path = toPath(property);\n\n // If the property is at the root (.level1) then toPath creates\n // an empty array element at the first index. Remove it.\n if (path.length > 0 && path[0] === '') {\n path.splice(0, 1);\n }\n if (message) {\n builder.addErrors(message, path);\n }\n });\n }\n return builder.ErrorSchema;\n }\n\n /** Converts an `errorSchema` into a list of `RJSFValidationErrors`\n *\n * @param errorSchema - The `ErrorSchema` instance to convert\n * @param [fieldPath=[]] - The current field path, defaults to [] if not specified\n */\n toErrorList(errorSchema?: ErrorSchema<T>, fieldPath: string[] = []) {\n if (!errorSchema) {\n return [];\n }\n let errorList: RJSFValidationError[] = [];\n if (ERRORS_KEY in errorSchema) {\n errorList = errorList.concat(\n errorSchema[ERRORS_KEY]!.map((message: string) => {\n const property = `.${fieldPath.join('.')}`;\n return {\n property,\n message,\n stack: `${property} ${message}`,\n };\n })\n );\n }\n return Object.keys(errorSchema).reduce((acc, key) => {\n if (key !== ERRORS_KEY) {\n const childSchema = (errorSchema as GenericObjectType)[key];\n if (isPlainObject(childSchema)) {\n acc = acc.concat(this.toErrorList(childSchema, [...fieldPath, key]));\n }\n }\n return acc;\n }, errorList);\n }\n\n /** Given a `formData` object, recursively creates a `FormValidation` error handling structure around it\n *\n * @param formData - The form data around which the error handler is created\n * @private\n */\n private createErrorHandler(formData: T): FormValidation<T> {\n const handler: FieldValidation = {\n // We store the list of errors for this node in a property named __errors\n // to avoid name collision with a possible sub schema field named\n // 'errors' (see `utils.toErrorSchema`).\n __errors: [],\n addError(message: string) {\n this.__errors!.push(message);\n },\n };\n if (Array.isArray(formData)) {\n return formData.reduce((acc, value, key) => {\n return { ...acc, [key]: this.createErrorHandler(value) };\n }, handler);\n }\n if (isPlainObject(formData)) {\n const formObject: GenericObjectType = formData as GenericObjectType;\n return Object.keys(formObject).reduce((acc, key) => {\n return { ...acc, [key]: this.createErrorHandler(formObject[key]) };\n }, handler as FormValidation<T>);\n }\n return handler as FormValidation<T>;\n }\n\n /** Unwraps the `errorHandler` structure into the associated `ErrorSchema`, stripping the `addError` functions from it\n *\n * @param errorHandler - The `FormValidation` error handling structure\n * @private\n */\n private unwrapErrorHandler(errorHandler: FormValidation<T>): ErrorSchema<T> {\n return Object.keys(errorHandler).reduce((acc, key) => {\n if (key === 'addError') {\n return acc;\n } else {\n const childSchema = (errorHandler as GenericObjectType)[key];\n if (isPlainObject(childSchema)) {\n return {\n ...acc,\n [key]: this.unwrapErrorHandler(childSchema),\n };\n }\n return { ...acc, [key]: childSchema };\n }\n }, {} as ErrorSchema<T>);\n }\n\n /** Transforming the error output from ajv to format used by @rjsf/utils.\n * At some point, components should be updated to support ajv.\n *\n * @param errors - The list of AJV errors to convert to `RJSFValidationErrors`\n * @protected\n */\n protected transformRJSFValidationErrors(\n errors: ErrorObject[] = [],\n uiSchema?: UiSchema<T, S, F>\n ): RJSFValidationError[] {\n return errors.map((e: ErrorObject) => {\n const { instancePath, keyword, params, schemaPath, parentSchema, ...rest } = e;\n let { message = '' } = rest;\n let property = instancePath.replace(/\\//g, '.');\n let stack = `${property} ${message}`.trim();\n\n if ('missingProperty' in params) {\n property = property ? `${property}.${params.missingProperty}` : params.missingProperty;\n const currentProperty: string = params.missingProperty;\n const uiSchemaTitle = getUiOptions(get(uiSchema, `${property.replace(/^\\./, '')}`)).title;\n\n if (uiSchemaTitle) {\n message = message.replace(currentProperty, uiSchemaTitle);\n } else {\n const parentSchemaTitle = get(parentSchema, [PROPERTIES_KEY, currentProperty, 'title']);\n\n if (parentSchemaTitle) {\n message = message.replace(currentProperty, parentSchemaTitle);\n }\n }\n\n stack = message;\n } else {\n const uiSchemaTitle = getUiOptions(get(uiSchema, `${property.replace(/^\\./, '')}`)).title;\n\n if (uiSchemaTitle) {\n stack = `'${uiSchemaTitle}' ${message}`.trim();\n } else {\n const parentSchemaTitle = parentSchema?.title;\n\n if (parentSchemaTitle) {\n stack = `'${parentSchemaTitle}' ${message}`.trim();\n }\n }\n }\n\n // put data in expected format\n return {\n name: keyword,\n property,\n message,\n params, // specific to ajv\n stack,\n schemaPath,\n };\n });\n }\n\n /** Runs the pure validation of the `schema` and `formData` without any of the RJSF functionality. Provided for use\n * by the playground. Returns the `errors` from the validation\n *\n * @param schema - The schema against which to validate the form data * @param schema\n * @param formData - The form data to validate\n */\n rawValidation<Result = any>(schema: RJSFSchema, formData?: T): { errors?: Result[]; validationError?: Error } {\n let compilationError: Error | undefined = undefined;\n let compiledValidator: ValidateFunction | undefined;\n if (schema['$id']) {\n compiledValidator = this.ajv.getSchema(schema['$id']);\n }\n try {\n if (compiledValidator === undefined) {\n compiledValidator = this.ajv.compile(schema);\n }\n compiledValidator(formData);\n } catch (err) {\n compilationError = err as Error;\n }\n\n let errors;\n if (compiledValidator) {\n if (typeof this.localizer === 'function') {\n this.localizer(compiledValidator.errors);\n }\n errors = compiledValidator.errors || undefined;\n\n // Clear errors to prevent persistent errors, see #1104\n compiledValidator.errors = null;\n }\n\n return {\n errors: errors as unknown as Result[],\n validationError: compilationError,\n };\n }\n\n /** This function processes the `formData` with an optional user contributed `customValidate` function, which receives\n * the form data and a `errorHandler` function that will be used to add custom validation errors for each field. Also\n * supports a `transformErrors` function that will take the raw AJV validation errors, prior to custom validation and\n * transform them in what ever way it chooses.\n *\n * @param formData - The form data to validate\n * @param schema - The schema against which to validate the form data\n * @param [customValidate] - An optional function that is used to perform custom validation\n * @param [transformErrors] - An optional function that is used to transform errors after AJV validation\n * @param [uiSchema] - An optional uiSchema that is passed to `transformErrors` and `customValidate`\n */\n validateFormData(\n formData: T | undefined,\n schema: S,\n customValidate?: CustomValidator<T, S, F>,\n transformErrors?: ErrorTransformer<T, S, F>,\n uiSchema?: UiSchema<T, S, F>\n ): ValidationData<T> {\n const rawErrors = this.rawValidation<ErrorObject>(schema, formData);\n const { validationError: invalidSchemaError } = rawErrors;\n let errors = this.transformRJSFValidationErrors(rawErrors.errors, uiSchema);\n\n if (invalidSchemaError) {\n errors = [...errors, { stack: invalidSchemaError!.message }];\n }\n if (typeof transformErrors === 'function') {\n errors = transformErrors(errors, uiSchema);\n }\n\n let errorSchema = this.toErrorSchema(errors);\n\n if (invalidSchemaError) {\n errorSchema = {\n ...errorSchema,\n $schema: {\n __errors: [invalidSchemaError!.message],\n },\n };\n }\n\n if (typeof customValidate !== 'function') {\n return { errors, errorSchema };\n }\n\n // Include form data with undefined values, which is required for custom validation.\n const newFormData = getDefaultFormState<T, S, F>(this, schema, formData, schema, true) as T;\n\n const errorHandler = customValidate(newFormData, this.createErrorHandler(newFormData), uiSchema);\n const userErrorSchema = this.unwrapErrorHandler(errorHandler);\n return mergeValidationData<T, S, F>(this, { errors, errorSchema }, userErrorSchema);\n }\n\n /** Takes a `node` object and transforms any contained `$ref` node variables with a prefix, recursively calling\n * `withIdRefPrefix` for any other elements.\n *\n * @param node - The object node to which a ROOT_SCHEMA_PREFIX is added when a REF_KEY is part of it\n * @private\n */\n private withIdRefPrefixObject(node: S) {\n for (const key in node) {\n const realObj: GenericObjectType = node;\n const value = realObj[key];\n if (key === REF_KEY && typeof value === 'string' && value.startsWith('#')) {\n realObj[key] = ROOT_SCHEMA_PREFIX + value;\n } else {\n realObj[key] = this.withIdRefPrefix(value);\n }\n }\n return node;\n }\n\n /** Takes a `node` object list and transforms any contained `$ref` node variables with a prefix, recursively calling\n * `withIdRefPrefix` for any other elements.\n *\n * @param node - The list of object nodes to which a ROOT_SCHEMA_PREFIX is added when a REF_KEY is part of it\n * @private\n */\n private withIdRefPrefixArray(node: S[]): S[] {\n for (let i = 0; i < node.length; i++) {\n node[i] = this.withIdRefPrefix(node[i]) as S;\n }\n return node;\n }\n\n /** Validates data against a schema, returning true if the data is valid, or\n * false otherwise. If the schema is invalid, then this function will return\n * false.\n *\n * @param schema - The schema against which to validate the form data\n * @param formData - The form data to validate\n * @param rootSchema - The root schema used to provide $ref resolutions\n */\n isValid(schema: S, formData: T | undefined, rootSchema: S) {\n const rootSchemaId = rootSchema['$id'] ?? ROOT_SCHEMA_PREFIX;\n try {\n // add the rootSchema ROOT_SCHEMA_PREFIX as id.\n // then rewrite the schema ref's to point to the rootSchema\n // this accounts for the case where schema have references to models\n // that lives in the rootSchema but not in the schema in question.\n if (this.ajv.getSchema(rootSchemaId) === undefined) {\n this.ajv.addSchema(rootSchema, rootSchemaId);\n }\n const schemaWithIdRefPrefix = this.withIdRefPrefix(schema) as S;\n let compiledValidator: ValidateFunction | undefined;\n if (schemaWithIdRefPrefix['$id']) {\n compiledValidator = this.ajv.getSchema(schemaWithIdRefPrefix['$id']);\n }\n if (compiledValidator === undefined) {\n compiledValidator = this.ajv.compile(schemaWithIdRefPrefix);\n }\n const result = compiledValidator(formData);\n return result as boolean;\n } catch (e) {\n console.warn('Error encountered compiling schema:', e);\n return false;\n } finally {\n // TODO: A function should be called if the root schema changes so we don't have to remove and recompile the schema every run.\n // make sure we remove the rootSchema from the global ajv instance\n this.ajv.removeSchema(rootSchemaId);\n }\n }\n\n /** Recursively prefixes all $ref's in a schema with `ROOT_SCHEMA_PREFIX`\n * This is used in isValid to make references to the rootSchema\n *\n * @param schemaNode - The object node to which a ROOT_SCHEMA_PREFIX is added when a REF_KEY is part of it\n * @protected\n */\n protected withIdRefPrefix(schemaNode: S | S[]): S | S[] {\n if (Array.isArray(schemaNode)) {\n return this.withIdRefPrefixArray([...schemaNode]);\n }\n if (isPlainObject(schemaNode)) {\n return this.withIdRefPrefixObject(clone<S>(schemaNode));\n }\n return schemaNode;\n }\n}\n","import { FormContextType, RJSFSchema, StrictRJSFSchema, ValidatorType } from '@rjsf/utils';\n\nimport { CustomValidatorOptionsType, Localizer } from './types';\nimport AJV8Validator from './validator';\n\n/** Creates and returns a customized implementation of the `ValidatorType` with the given customization `options` if\n * provided.\n *\n * @param [options={}] - The `CustomValidatorOptionsType` options that are used to create the `ValidatorType` instance\n * @param [localizer] - If provided, is used to localize a list of Ajv `ErrorObject`s\n */\nexport default function customizeValidator<\n T = any,\n S extends StrictRJSFSchema = RJSFSchema,\n F extends FormContextType = any\n>(options: CustomValidatorOptionsType = {}, localizer?: Localizer): ValidatorType<T, S, F> {\n return new AJV8Validator<T, S, F>(options, localizer);\n}\n","import customizeValidator from './customizeValidator';\n\nexport { customizeValidator };\nexport * from './types';\n\nexport default customizeValidator();\n"],"names":["AJV_CONFIG","allErrors","multipleOfPrecision","strict","verbose","COLOR_FORMAT_REGEX","DATA_URL_FORMAT_REGEX","createAjvInstance","additionalMetaSchemas","customFormats","ajvOptionsOverrides","ajvFormatOptions","AjvClass","Ajv","ajv","_extends","addFormats","addFormat","addKeyword","ADDITIONAL_PROPERTY_FLAG","RJSF_ADDITONAL_PROPERTIES_FLAG","Array","isArray","addMetaSchema","isObject","Object","keys","forEach","formatName","ROOT_SCHEMA_PREFIX","AJV8Validator","options","localizer","_proto","prototype","toErrorSchema","errors","builder","ErrorSchemaBuilder","length","error","property","message","path","toPath","splice","addErrors","ErrorSchema","toErrorList","errorSchema","fieldPath","_this","errorList","ERRORS_KEY","concat","map","join","stack","reduce","acc","key","childSchema","isPlainObject","createErrorHandler","formData","_this2","handler","__errors","addError","push","value","_extends2","formObject","_extends3","unwrapErrorHandler","errorHandler","_this3","_extends5","_extends4","transformRJSFValidationErrors","uiSchema","e","instancePath","keyword","params","schemaPath","parentSchema","rest","_objectWithoutPropertiesLoose","_excluded","_rest$message","replace","trim","missingProperty","currentProperty","uiSchemaTitle","getUiOptions","get","title","parentSchemaTitle","PROPERTIES_KEY","name","rawValidation","schema","compilationError","undefined","compiledValidator","getSchema","compile","err","validationError","validateFormData","customValidate","transformErrors","rawErrors","invalidSchemaError","$schema","newFormData","getDefaultFormState","userErrorSchema","mergeValidationData","withIdRefPrefixObject","node","realObj","REF_KEY","startsWith","withIdRefPrefix","withIdRefPrefixArray","i","isValid","rootSchema","_rootSchema$$id","rootSchemaId","addSchema","schemaWithIdRefPrefix","result","console","warn","removeSchema","schemaNode","clone","customizeValidator"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOO,IAAMA,UAAU,GAAY;AACjCC,EAAAA,SAAS,EAAE,IAAI;AACfC,EAAAA,mBAAmB,EAAE,CAAC;AACtBC,EAAAA,MAAM,EAAE,KAAK;AACbC,EAAAA,OAAO,EAAE,IAAA;CACD,CAAA;AACH,IAAMC,kBAAkB,GAC7B,4YAA4Y,CAAA;AACvY,IAAMC,qBAAqB,GAAG,2DAA2D,CAAA;AAEhG;;;;;;;;;;;;;;AAcG;AACqB,SAAAC,iBAAiBA,CACvCC,qBAA2E,EAC3EC,aAA2D,EAC3DC,qBACAC,gBAA+C,EAC/CC,UAA0B;AAAA,EAAA,IAF1BF;IAAAA,sBAAyE,EAAE,CAAA;AAAA,GAAA;AAAA,EAAA,IAE3EE;AAAAA,IAAAA,WAAuBC,uBAAG,CAAA;AAAA,GAAA;EAE1B,IAAMC,GAAG,GAAG,IAAIF,QAAQ,CAAAG,QAAA,CAAMf,EAAAA,EAAAA,UAAU,EAAKU,mBAAmB,CAAG,CAAA,CAAA;AACnE,EAAA,IAAIC,gBAAgB,EAAE;AACpBK,IAAAA,8BAAU,CAACF,GAAG,EAAEH,gBAAgB,CAAC,CAAA;AAClC,GAAA,MAAM,IAAIA,gBAAgB,KAAK,KAAK,EAAE;IACrCK,8BAAU,CAACF,GAAG,CAAC,CAAA;AAChB,GAAA;AAED;AACAA,EAAAA,GAAG,CAACG,SAAS,CAAC,UAAU,EAAEX,qBAAqB,CAAC,CAAA;AAChDQ,EAAAA,GAAG,CAACG,SAAS,CAAC,OAAO,EAAEZ,kBAAkB,CAAC,CAAA;AAE1C;AACAS,EAAAA,GAAG,CAACI,UAAU,CAACC,8BAAwB,CAAC,CAAA;AACxCL,EAAAA,GAAG,CAACI,UAAU,CAACE,oCAA8B,CAAC,CAAA;AAE9C;AACA,EAAA,IAAIC,KAAK,CAACC,OAAO,CAACd,qBAAqB,CAAC,EAAE;AACxCM,IAAAA,GAAG,CAACS,aAAa,CAACf,qBAAqB,CAAC,CAAA;AACzC,GAAA;AAED;AACA,EAAA,IAAIgB,4BAAQ,CAACf,aAAa,CAAC,EAAE;IAC3BgB,MAAM,CAACC,IAAI,CAACjB,aAAa,CAAC,CAACkB,OAAO,CAAC,UAACC,UAAU,EAAI;MAChDd,GAAG,CAACG,SAAS,CAACW,UAAU,EAAEnB,aAAa,CAACmB,UAAU,CAAC,CAAC,CAAA;AACtD,KAAC,CAAC,CAAA;AACH,GAAA;AAED,EAAA,OAAOd,GAAG,CAAA;AACZ;;;ACpCA,IAAMe,kBAAkB,GAAG,mBAAmB,CAAA;AAE9C;AACG;AADH,IAEqBC,aAAa,gBAAA,YAAA;AAehC;;;;AAIG;AACH,EAAA,SAAAA,aAAYC,CAAAA,OAAmC,EAAEC,SAAqB,EAAA;AAjBtE;;;AAGG;AAHH,IAAA,IAAA,CAIQlB,GAAG,GAAA,KAAA,CAAA,CAAA;AAEX;;;AAGG;AAHH,IAAA,IAAA,CAISkB,SAAS,GAAA,KAAA,CAAA,CAAA;AAQhB,IAAA,IAAQxB,qBAAqB,GAAqEuB,OAAO,CAAjGvB,qBAAqB;MAAEC,aAAa,GAAsDsB,OAAO,CAA1EtB,aAAa;MAAEC,mBAAmB,GAAiCqB,OAAO,CAA3DrB,mBAAmB;MAAEC,gBAAgB,GAAeoB,OAAO,CAAtCpB,gBAAgB;MAAEC,QAAQ,GAAKmB,OAAO,CAApBnB,QAAQ,CAAA;AAC7F,IAAA,IAAI,CAACE,GAAG,GAAGP,iBAAiB,CAACC,qBAAqB,EAAEC,aAAa,EAAEC,mBAAmB,EAAEC,gBAAgB,EAAEC,QAAQ,CAAC,CAAA;IACnH,IAAI,CAACoB,SAAS,GAAGA,SAAS,CAAA;AAC5B,GAAA;AAEA;;;;;;;;;;;;;;;;;;AAkBG;AAlBH,EAAA,IAAAC,MAAA,GAAAH,aAAA,CAAAI,SAAA,CAAA;AAAAD,EAAAA,MAAA,CAmBQE,aAAa,GAAb,SAAAA,aAAAA,CAAcC,MAA6B,EAAA;AACjD,IAAA,IAAMC,OAAO,GAAG,IAAIC,wBAAkB,EAAK,CAAA;IAC3C,IAAIF,MAAM,CAACG,MAAM,EAAE;AACjBH,MAAAA,MAAM,CAACT,OAAO,CAAC,UAACa,KAAK,EAAI;AACvB,QAAA,IAAQC,QAAQ,GAAcD,KAAK,CAA3BC,QAAQ;UAAEC,OAAO,GAAKF,KAAK,CAAjBE,OAAO,CAAA;AACzB,QAAA,IAAMC,IAAI,GAAGC,0BAAM,CAACH,QAAQ,CAAC,CAAA;AAE7B;AACA;AACA,QAAA,IAAIE,IAAI,CAACJ,MAAM,GAAG,CAAC,IAAII,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE;AACrCA,UAAAA,IAAI,CAACE,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;AAClB,SAAA;AACD,QAAA,IAAIH,OAAO,EAAE;AACXL,UAAAA,OAAO,CAACS,SAAS,CAACJ,OAAO,EAAEC,IAAI,CAAC,CAAA;AACjC,SAAA;AACH,OAAC,CAAC,CAAA;AACH,KAAA;IACD,OAAON,OAAO,CAACU,WAAW,CAAA;AAC5B,GAAA;AAEA;;;;AAIG,MAJH;EAAAd,MAAA,CAKAe,WAAW,GAAX,SAAAA,YAAYC,WAA4B,EAAEC,SAAA,EAAwB;AAAA,IAAA,IAAAC,KAAA,GAAA,IAAA,CAAA;AAAA,IAAA,IAAxBD,SAAA,KAAA,KAAA,CAAA,EAAA;AAAAA,MAAAA,SAAA,GAAsB,EAAE,CAAA;AAAA,KAAA;IAChE,IAAI,CAACD,WAAW,EAAE;AAChB,MAAA,OAAO,EAAE,CAAA;AACV,KAAA;IACD,IAAIG,SAAS,GAA0B,EAAE,CAAA;IACzC,IAAIC,gBAAU,IAAIJ,WAAW,EAAE;AAC7BG,MAAAA,SAAS,GAAGA,SAAS,CAACE,MAAM,CAC1BL,WAAW,CAACI,gBAAU,CAAE,CAACE,GAAG,CAAC,UAACb,OAAe,EAAI;AAC/C,QAAA,IAAMD,QAAQ,GAAOS,GAAAA,GAAAA,SAAS,CAACM,IAAI,CAAC,GAAG,CAAG,CAAA;QAC1C,OAAO;AACLf,UAAAA,QAAQ,EAARA,QAAQ;AACRC,UAAAA,OAAO,EAAPA,OAAO;UACPe,KAAK,EAAKhB,QAAQ,GAAIC,GAAAA,GAAAA,OAAAA;SACvB,CAAA;AACH,OAAC,CAAC,CACH,CAAA;AACF,KAAA;AACD,IAAA,OAAOjB,MAAM,CAACC,IAAI,CAACuB,WAAW,CAAC,CAACS,MAAM,CAAC,UAACC,GAAG,EAAEC,GAAG,EAAI;MAClD,IAAIA,GAAG,KAAKP,gBAAU,EAAE;AACtB,QAAA,IAAMQ,WAAW,GAAIZ,WAAiC,CAACW,GAAG,CAAC,CAAA;AAC3D,QAAA,IAAIE,iCAAa,CAACD,WAAW,CAAC,EAAE;AAC9BF,UAAAA,GAAG,GAAGA,GAAG,CAACL,MAAM,CAACH,KAAI,CAACH,WAAW,CAACa,WAAW,KAAAP,MAAA,CAAMJ,SAAS,EAAEU,CAAAA,GAAG,GAAE,CAAC,CAAA;AACrE,SAAA;AACF,OAAA;AACD,MAAA,OAAOD,GAAG,CAAA;KACX,EAAEP,SAAS,CAAC,CAAA;AACf,GAAA;AAEA;;;;AAIG,MAJH;AAAAnB,EAAAA,MAAA,CAKQ8B,kBAAkB,GAAlB,SAAAA,kBAAAA,CAAmBC,QAAW,EAAA;AAAA,IAAA,IAAAC,MAAA,GAAA,IAAA,CAAA;AACpC,IAAA,IAAMC,OAAO,GAAoB;AAC/B;AACA;AACA;AACAC,MAAAA,QAAQ,EAAE,EAAE;MACZC,QAAQ,EAAA,SAAAA,QAAC1B,CAAAA,OAAe,EAAA;AACtB,QAAA,IAAI,CAACyB,QAAS,CAACE,IAAI,CAAC3B,OAAO,CAAC,CAAA;AAC9B,OAAA;KACD,CAAA;AACD,IAAA,IAAIrB,KAAK,CAACC,OAAO,CAAC0C,QAAQ,CAAC,EAAE;MAC3B,OAAOA,QAAQ,CAACN,MAAM,CAAC,UAACC,GAAG,EAAEW,KAAK,EAAEV,GAAG,EAAI;AAAA,QAAA,IAAAW,SAAA,CAAA;AACzC,QAAA,OAAAxD,QAAA,CAAY4C,EAAAA,EAAAA,GAAG,GAAAY,SAAA,OAAAA,SAAA,CAAGX,GAAG,CAAA,GAAGK,MAAI,CAACF,kBAAkB,CAACO,KAAK,CAAC,EAAAC,SAAA,EAAA,CAAA;OACvD,EAAEL,OAAO,CAAC,CAAA;AACZ,KAAA;AACD,IAAA,IAAIJ,iCAAa,CAACE,QAAQ,CAAC,EAAE;MAC3B,IAAMQ,UAAU,GAAsBR,QAA6B,CAAA;AACnE,MAAA,OAAOvC,MAAM,CAACC,IAAI,CAAC8C,UAAU,CAAC,CAACd,MAAM,CAAC,UAACC,GAAG,EAAEC,GAAG,EAAI;AAAA,QAAA,IAAAa,SAAA,CAAA;QACjD,OAAA1D,QAAA,KAAY4C,GAAG,GAAAc,SAAA,GAAAA,EAAAA,EAAAA,SAAA,CAAGb,GAAG,CAAA,GAAGK,MAAI,CAACF,kBAAkB,CAACS,UAAU,CAACZ,GAAG,CAAC,CAAC,EAAAa,SAAA,EAAA,CAAA;OACjE,EAAEP,OAA4B,CAAC,CAAA;AACjC,KAAA;AACD,IAAA,OAAOA,OAA4B,CAAA;AACrC,GAAA;AAEA;;;;AAIG,MAJH;AAAAjC,EAAAA,MAAA,CAKQyC,kBAAkB,GAAlB,SAAAA,kBAAAA,CAAmBC,YAA+B,EAAA;AAAA,IAAA,IAAAC,MAAA,GAAA,IAAA,CAAA;AACxD,IAAA,OAAOnD,MAAM,CAACC,IAAI,CAACiD,YAAY,CAAC,CAACjB,MAAM,CAAC,UAACC,GAAG,EAAEC,GAAG,EAAI;MACnD,IAAIA,GAAG,KAAK,UAAU,EAAE;AACtB,QAAA,OAAOD,GAAG,CAAA;AACX,OAAA,MAAM;AAAA,QAAA,IAAAkB,SAAA,CAAA;AACL,QAAA,IAAMhB,WAAW,GAAIc,YAAkC,CAACf,GAAG,CAAC,CAAA;AAC5D,QAAA,IAAIE,iCAAa,CAACD,WAAW,CAAC,EAAE;AAAA,UAAA,IAAAiB,SAAA,CAAA;AAC9B,UAAA,OAAA/D,QAAA,CACK4C,EAAAA,EAAAA,GAAG,GAAAmB,SAAA,OAAAA,SAAA,CACLlB,GAAG,CAAA,GAAGgB,MAAI,CAACF,kBAAkB,CAACb,WAAW,CAAC,EAAAiB,SAAA,EAAA,CAAA;AAE9C,SAAA;AACD,QAAA,OAAA/D,QAAA,CAAA,EAAA,EAAY4C,GAAG,GAAAkB,SAAA,GAAA,EAAA,EAAAA,SAAA,CAAGjB,GAAG,CAAA,GAAGC,WAAW,EAAAgB,SAAA,EAAA,CAAA;AACpC,OAAA;KACF,EAAE,EAAoB,CAAC,CAAA;AAC1B,GAAA;AAEA;;;;;AAKG,MALH;EAAA5C,MAAA,CAMU8C,6BAA6B,GAA7B,SAAAA,8BACR3C,MAAA,EACA4C,QAA4B,EAAA;AAAA,IAAA,IAD5B5C,MAAA,KAAA,KAAA,CAAA,EAAA;AAAAA,MAAAA,MAAA,GAAwB,EAAE,CAAA;AAAA,KAAA;AAG1B,IAAA,OAAOA,MAAM,CAACmB,GAAG,CAAC,UAAC0B,CAAc,EAAI;AACnC,MAAA,IAAQC,YAAY,GAAyDD,CAAC,CAAtEC,YAAY;QAAEC,OAAO,GAAgDF,CAAC,CAAxDE,OAAO;QAAEC,MAAM,GAAwCH,CAAC,CAA/CG,MAAM;QAAEC,UAAU,GAA4BJ,CAAC,CAAvCI,UAAU;QAAEC,YAAY,GAAcL,CAAC,CAA3BK,YAAY;AAAKC,QAAAA,IAAI,GAAAC,6BAAA,CAAKP,CAAC,EAAAQ,SAAA,CAAA,CAAA;AAC9E,MAAA,IAAAC,aAAA,GAAuBH,IAAI,CAArB7C,OAAO;AAAPA,QAAAA,OAAO,GAAAgD,aAAA,KAAG,KAAA,CAAA,GAAA,EAAE,GAAAA,aAAA,CAAA;MAClB,IAAIjD,QAAQ,GAAGyC,YAAY,CAACS,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAA;MAC/C,IAAIlC,KAAK,GAAG,CAAGhB,QAAQ,SAAIC,OAAO,EAAGkD,IAAI,EAAE,CAAA;MAE3C,IAAI,iBAAiB,IAAIR,MAAM,EAAE;QAC/B3C,QAAQ,GAAGA,QAAQ,GAAMA,QAAQ,GAAA,GAAA,GAAI2C,MAAM,CAACS,eAAe,GAAKT,MAAM,CAACS,eAAe,CAAA;AACtF,QAAA,IAAMC,eAAe,GAAWV,MAAM,CAACS,eAAe,CAAA;AACtD,QAAA,IAAME,aAAa,GAAGC,kBAAY,CAACC,uBAAG,CAACjB,QAAQ,EAAKvC,EAAAA,GAAAA,QAAQ,CAACkD,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAG,CAAC,CAACO,KAAK,CAAA;AAEzF,QAAA,IAAIH,aAAa,EAAE;UACjBrD,OAAO,GAAGA,OAAO,CAACiD,OAAO,CAACG,eAAe,EAAEC,aAAa,CAAC,CAAA;AAC1D,SAAA,MAAM;AACL,UAAA,IAAMI,iBAAiB,GAAGF,uBAAG,CAACX,YAAY,EAAE,CAACc,oBAAc,EAAEN,eAAe,EAAE,OAAO,CAAC,CAAC,CAAA;AAEvF,UAAA,IAAIK,iBAAiB,EAAE;YACrBzD,OAAO,GAAGA,OAAO,CAACiD,OAAO,CAACG,eAAe,EAAEK,iBAAiB,CAAC,CAAA;AAC9D,WAAA;AACF,SAAA;AAED1C,QAAAA,KAAK,GAAGf,OAAO,CAAA;AAChB,OAAA,MAAM;AACL,QAAA,IAAMqD,cAAa,GAAGC,kBAAY,CAACC,uBAAG,CAACjB,QAAQ,EAAKvC,EAAAA,GAAAA,QAAQ,CAACkD,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAG,CAAC,CAACO,KAAK,CAAA;AAEzF,QAAA,IAAIH,cAAa,EAAE;AACjBtC,UAAAA,KAAK,GAAG,CAAIsC,GAAAA,GAAAA,cAAa,UAAKrD,OAAO,EAAGkD,IAAI,EAAE,CAAA;AAC/C,SAAA,MAAM;UACL,IAAMO,kBAAiB,GAAGb,YAAY,KAAA,IAAA,IAAZA,YAAY,KAAZA,KAAAA,CAAAA,GAAAA,KAAAA,CAAAA,GAAAA,YAAY,CAAEY,KAAK,CAAA;AAE7C,UAAA,IAAIC,kBAAiB,EAAE;AACrB1C,YAAAA,KAAK,GAAG,CAAI0C,GAAAA,GAAAA,kBAAiB,UAAKzD,OAAO,EAAGkD,IAAI,EAAE,CAAA;AACnD,WAAA;AACF,SAAA;AACF,OAAA;AAED;MACA,OAAO;AACLS,QAAAA,IAAI,EAAElB,OAAO;AACb1C,QAAAA,QAAQ,EAARA,QAAQ;AACRC,QAAAA,OAAO,EAAPA,OAAO;AACP0C,QAAAA,MAAM,EAANA,MAAM;AACN3B,QAAAA,KAAK,EAALA,KAAK;AACL4B,QAAAA,UAAU,EAAVA,UAAAA;OACD,CAAA;AACH,KAAC,CAAC,CAAA;AACJ,GAAA;AAEA;;;;;AAKG,MALH;EAAApD,MAAA,CAMAqE,aAAa,GAAb,SAAAA,cAA4BC,MAAkB,EAAEvC,QAAY,EAAA;IAC1D,IAAIwC,gBAAgB,GAAsBC,SAAS,CAAA;AACnD,IAAA,IAAIC,iBAA+C,CAAA;AACnD,IAAA,IAAIH,MAAM,CAAC,KAAK,CAAC,EAAE;MACjBG,iBAAiB,GAAG,IAAI,CAAC5F,GAAG,CAAC6F,SAAS,CAACJ,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;AACtD,KAAA;IACD,IAAI;MACF,IAAIG,iBAAiB,KAAKD,SAAS,EAAE;QACnCC,iBAAiB,GAAG,IAAI,CAAC5F,GAAG,CAAC8F,OAAO,CAACL,MAAM,CAAC,CAAA;AAC7C,OAAA;MACDG,iBAAiB,CAAC1C,QAAQ,CAAC,CAAA;KAC5B,CAAC,OAAO6C,GAAG,EAAE;AACZL,MAAAA,gBAAgB,GAAGK,GAAY,CAAA;AAChC,KAAA;AAED,IAAA,IAAIzE,MAAM,CAAA;AACV,IAAA,IAAIsE,iBAAiB,EAAE;AACrB,MAAA,IAAI,OAAO,IAAI,CAAC1E,SAAS,KAAK,UAAU,EAAE;AACxC,QAAA,IAAI,CAACA,SAAS,CAAC0E,iBAAiB,CAACtE,MAAM,CAAC,CAAA;AACzC,OAAA;AACDA,MAAAA,MAAM,GAAGsE,iBAAiB,CAACtE,MAAM,IAAIqE,SAAS,CAAA;AAE9C;MACAC,iBAAiB,CAACtE,MAAM,GAAG,IAAI,CAAA;AAChC,KAAA;IAED,OAAO;AACLA,MAAAA,MAAM,EAAEA,MAA6B;AACrC0E,MAAAA,eAAe,EAAEN,gBAAAA;KAClB,CAAA;AACH,GAAA;AAEA;;;;;;;;;;AAUG,MAVH;AAAAvE,EAAAA,MAAA,CAWA8E,gBAAgB,GAAhB,SAAAA,iBACE/C,QAAuB,EACvBuC,MAAS,EACTS,cAAyC,EACzCC,eAA2C,EAC3CjC,QAA4B,EAAA;IAE5B,IAAMkC,SAAS,GAAG,IAAI,CAACZ,aAAa,CAAcC,MAAM,EAAEvC,QAAQ,CAAC,CAAA;AACnE,IAAA,IAAyBmD,kBAAkB,GAAKD,SAAS,CAAjDJ,eAAe,CAAA;IACvB,IAAI1E,MAAM,GAAG,IAAI,CAAC2C,6BAA6B,CAACmC,SAAS,CAAC9E,MAAM,EAAE4C,QAAQ,CAAC,CAAA;AAE3E,IAAA,IAAImC,kBAAkB,EAAE;AACtB/E,MAAAA,MAAM,GAAAkB,EAAAA,CAAAA,MAAA,CAAOlB,MAAM,EAAE,CAAA;QAAEqB,KAAK,EAAE0D,kBAAmB,CAACzE,OAAAA;AAAO,OAAE,CAAC,CAAA,CAAA;AAC7D,KAAA;AACD,IAAA,IAAI,OAAOuE,eAAe,KAAK,UAAU,EAAE;AACzC7E,MAAAA,MAAM,GAAG6E,eAAe,CAAC7E,MAAM,EAAE4C,QAAQ,CAAC,CAAA;AAC3C,KAAA;AAED,IAAA,IAAI/B,WAAW,GAAG,IAAI,CAACd,aAAa,CAACC,MAAM,CAAC,CAAA;AAE5C,IAAA,IAAI+E,kBAAkB,EAAE;MACtBlE,WAAW,GAAAlC,QAAA,CAAA,EAAA,EACNkC,WAAW,EAAA;AACdmE,QAAAA,OAAO,EAAE;AACPjD,UAAAA,QAAQ,EAAE,CAACgD,kBAAmB,CAACzE,OAAO,CAAA;AACvC,SAAA;OACF,CAAA,CAAA;AACF,KAAA;AAED,IAAA,IAAI,OAAOsE,cAAc,KAAK,UAAU,EAAE;MACxC,OAAO;AAAE5E,QAAAA,MAAM,EAANA,MAAM;AAAEa,QAAAA,WAAW,EAAXA,WAAAA;OAAa,CAAA;AAC/B,KAAA;AAED;AACA,IAAA,IAAMoE,WAAW,GAAGC,yBAAmB,CAAU,IAAI,EAAEf,MAAM,EAAEvC,QAAQ,EAAEuC,MAAM,EAAE,IAAI,CAAM,CAAA;AAE3F,IAAA,IAAM5B,YAAY,GAAGqC,cAAc,CAACK,WAAW,EAAE,IAAI,CAACtD,kBAAkB,CAACsD,WAAW,CAAC,EAAErC,QAAQ,CAAC,CAAA;AAChG,IAAA,IAAMuC,eAAe,GAAG,IAAI,CAAC7C,kBAAkB,CAACC,YAAY,CAAC,CAAA;IAC7D,OAAO6C,yBAAmB,CAAU,IAAI,EAAE;AAAEpF,MAAAA,MAAM,EAANA,MAAM;AAAEa,MAAAA,WAAW,EAAXA,WAAAA;KAAa,EAAEsE,eAAe,CAAC,CAAA;AACrF,GAAA;AAEA;;;;;AAKG,MALH;AAAAtF,EAAAA,MAAA,CAMQwF,qBAAqB,GAArB,SAAAA,qBAAAA,CAAsBC,IAAO,EAAA;AACnC,IAAA,KAAK,IAAM9D,GAAG,IAAI8D,IAAI,EAAE;MACtB,IAAMC,OAAO,GAAsBD,IAAI,CAAA;AACvC,MAAA,IAAMpD,KAAK,GAAGqD,OAAO,CAAC/D,GAAG,CAAC,CAAA;AAC1B,MAAA,IAAIA,GAAG,KAAKgE,aAAO,IAAI,OAAOtD,KAAK,KAAK,QAAQ,IAAIA,KAAK,CAACuD,UAAU,CAAC,GAAG,CAAC,EAAE;AACzEF,QAAAA,OAAO,CAAC/D,GAAG,CAAC,GAAG/B,kBAAkB,GAAGyC,KAAK,CAAA;AAC1C,OAAA,MAAM;QACLqD,OAAO,CAAC/D,GAAG,CAAC,GAAG,IAAI,CAACkE,eAAe,CAACxD,KAAK,CAAC,CAAA;AAC3C,OAAA;AACF,KAAA;AACD,IAAA,OAAOoD,IAAI,CAAA;AACb,GAAA;AAEA;;;;;AAKG,MALH;AAAAzF,EAAAA,MAAA,CAMQ8F,oBAAoB,GAApB,SAAAA,oBAAAA,CAAqBL,IAAS,EAAA;AACpC,IAAA,KAAK,IAAIM,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGN,IAAI,CAACnF,MAAM,EAAEyF,CAAC,EAAE,EAAE;AACpCN,MAAAA,IAAI,CAACM,CAAC,CAAC,GAAG,IAAI,CAACF,eAAe,CAACJ,IAAI,CAACM,CAAC,CAAC,CAAM,CAAA;AAC7C,KAAA;AACD,IAAA,OAAON,IAAI,CAAA;AACb,GAAA;AAEA;;;;;;;AAOG,MAPH;EAAAzF,MAAA,CAQAgG,OAAO,GAAP,SAAAA,OAAAA,CAAQ1B,MAAS,EAAEvC,QAAuB,EAAEkE,UAAa,EAAA;AAAA,IAAA,IAAAC,eAAA,CAAA;IACvD,IAAMC,YAAY,GAAAD,CAAAA,eAAA,GAAGD,UAAU,CAAC,KAAK,CAAC,KAAA,IAAA,GAAAC,eAAA,GAAItG,kBAAkB,CAAA;IAC5D,IAAI;AACF;AACA;AACA;AACA;MACA,IAAI,IAAI,CAACf,GAAG,CAAC6F,SAAS,CAACyB,YAAY,CAAC,KAAK3B,SAAS,EAAE;QAClD,IAAI,CAAC3F,GAAG,CAACuH,SAAS,CAACH,UAAU,EAAEE,YAAY,CAAC,CAAA;AAC7C,OAAA;AACD,MAAA,IAAME,qBAAqB,GAAG,IAAI,CAACR,eAAe,CAACvB,MAAM,CAAM,CAAA;AAC/D,MAAA,IAAIG,iBAA+C,CAAA;AACnD,MAAA,IAAI4B,qBAAqB,CAAC,KAAK,CAAC,EAAE;QAChC5B,iBAAiB,GAAG,IAAI,CAAC5F,GAAG,CAAC6F,SAAS,CAAC2B,qBAAqB,CAAC,KAAK,CAAC,CAAC,CAAA;AACrE,OAAA;MACD,IAAI5B,iBAAiB,KAAKD,SAAS,EAAE;QACnCC,iBAAiB,GAAG,IAAI,CAAC5F,GAAG,CAAC8F,OAAO,CAAC0B,qBAAqB,CAAC,CAAA;AAC5D,OAAA;AACD,MAAA,IAAMC,MAAM,GAAG7B,iBAAiB,CAAC1C,QAAQ,CAAC,CAAA;AAC1C,MAAA,OAAOuE,MAAiB,CAAA;KACzB,CAAC,OAAOtD,CAAC,EAAE;AACVuD,MAAAA,OAAO,CAACC,IAAI,CAAC,qCAAqC,EAAExD,CAAC,CAAC,CAAA;AACtD,MAAA,OAAO,KAAK,CAAA;AACb,KAAA,SAAS;AACR;AACA;AACA,MAAA,IAAI,CAACnE,GAAG,CAAC4H,YAAY,CAACN,YAAY,CAAC,CAAA;AACpC,KAAA;AACH,GAAA;AAEA;;;;;AAKG,MALH;AAAAnG,EAAAA,MAAA,CAMU6F,eAAe,GAAf,SAAAA,eAAAA,CAAgBa,UAAmB,EAAA;AAC3C,IAAA,IAAItH,KAAK,CAACC,OAAO,CAACqH,UAAU,CAAC,EAAE;AAC7B,MAAA,OAAO,IAAI,CAACZ,oBAAoB,IAAAzE,MAAA,CAAKqF,UAAU,CAAE,CAAA,CAAA;AAClD,KAAA;AACD,IAAA,IAAI7E,iCAAa,CAAC6E,UAAU,CAAC,EAAE;MAC7B,OAAO,IAAI,CAAClB,qBAAqB,CAACmB,yBAAK,CAAID,UAAU,CAAC,CAAC,CAAA;AACxD,KAAA;AACD,IAAA,OAAOA,UAAU,CAAA;GAClB,CAAA;AAAA,EAAA,OAAA7G,aAAA,CAAA;AAAA,CAAA,EAAA;;AC3ZH;;;;;AAKG;AACqB,SAAA+G,kBAAkBA,CAIxC9G,OAAsC,EAAIC,SAAqB,EAAA;AAAA,EAAA,IAA/DD,OAAsC,KAAA,KAAA,CAAA,EAAA;IAAtCA,OAAsC,GAAA,EAAE,CAAA;AAAA,GAAA;AACxC,EAAA,OAAO,IAAID,aAAa,CAAUC,OAAO,EAAEC,SAAS,CAAC,CAAA;AACvD;;ACZA,YAAA,aAAe6G,kBAAkB,EAAE;;;;;"}
|
|
1
|
+
{"version":3,"file":"validator-ajv8.cjs.development.js","sources":["../src/createAjvInstance.ts","../src/validator.ts","../src/customizeValidator.ts","../src/index.ts"],"sourcesContent":["import Ajv, { Options } from 'ajv';\nimport addFormats, { FormatsPluginOptions } from 'ajv-formats';\nimport isObject from 'lodash/isObject';\n\nimport { CustomValidatorOptionsType } from './types';\nimport { ADDITIONAL_PROPERTY_FLAG, RJSF_ADDITONAL_PROPERTIES_FLAG } from '@rjsf/utils';\n\nexport const AJV_CONFIG: Options = {\n allErrors: true,\n multipleOfPrecision: 8,\n strict: false,\n verbose: true,\n} as const;\nexport const COLOR_FORMAT_REGEX =\n /^(#?([0-9A-Fa-f]{3}){1,2}\\b|aqua|black|blue|fuchsia|gray|green|lime|maroon|navy|olive|orange|purple|red|silver|teal|white|yellow|(rgb\\(\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*,\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*,\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*\\))|(rgb\\(\\s*(\\d?\\d%|100%)+\\s*,\\s*(\\d?\\d%|100%)+\\s*,\\s*(\\d?\\d%|100%)+\\s*\\)))$/;\nexport const DATA_URL_FORMAT_REGEX = /^data:([a-z]+\\/[a-z0-9-+.]+)?;(?:name=(.*);)?base64,(.*)$/;\n\n/** Creates an Ajv version 8 implementation object with standard support for the 'color` and `data-url` custom formats.\n * If `additionalMetaSchemas` are provided then the Ajv instance is modified to add each of the meta schemas in the\n * list. If `customFormats` are provided then those additional formats are added to the list of supported formats. If\n * `ajvOptionsOverrides` are provided then they are spread on top of the default `AJV_CONFIG` options when constructing\n * the `Ajv` instance. With Ajv v8, the JSON Schema formats are not provided by default, but can be plugged in. By\n * default, all formats from the `ajv-formats` library are added. To disable this capability, set the `ajvFormatOptions`\n * parameter to `false`. Additionally, you can configure the `ajv-formats` by providing a custom set of\n * [format options](https://github.com/ajv-validator/ajv-formats) to the `ajvFormatOptions` parameter.\n *\n * @param [additionalMetaSchemas] - The list of additional meta schemas that the validator can access\n * @param [customFormats] - The set of additional custom formats that the validator will support\n * @param [ajvOptionsOverrides={}] - The set of validator config override options\n * @param [ajvFormatOptions] - The `ajv-format` options to use when adding formats to `ajv`; pass `false` to disable it\n * @param [AjvClass] - The `Ajv` class to use when creating the validator instance\n */\nexport default function createAjvInstance(\n additionalMetaSchemas?: CustomValidatorOptionsType['additionalMetaSchemas'],\n customFormats?: CustomValidatorOptionsType['customFormats'],\n ajvOptionsOverrides: CustomValidatorOptionsType['ajvOptionsOverrides'] = {},\n ajvFormatOptions?: FormatsPluginOptions | false,\n AjvClass: typeof Ajv = Ajv\n) {\n const ajv = new AjvClass({ ...AJV_CONFIG, ...ajvOptionsOverrides });\n if (ajvFormatOptions) {\n addFormats(ajv, ajvFormatOptions);\n } else if (ajvFormatOptions !== false) {\n addFormats(ajv);\n }\n\n // add custom formats\n ajv.addFormat('data-url', DATA_URL_FORMAT_REGEX);\n ajv.addFormat('color', COLOR_FORMAT_REGEX);\n\n // Add RJSF-specific additional properties keywords so Ajv doesn't report errors if strict is enabled.\n ajv.addKeyword(ADDITIONAL_PROPERTY_FLAG);\n ajv.addKeyword(RJSF_ADDITONAL_PROPERTIES_FLAG);\n\n // add more schemas to validate against\n if (Array.isArray(additionalMetaSchemas)) {\n ajv.addMetaSchema(additionalMetaSchemas);\n }\n\n // add more custom formats to validate against\n if (isObject(customFormats)) {\n Object.keys(customFormats).forEach((formatName) => {\n ajv.addFormat(formatName, customFormats[formatName]);\n });\n }\n\n return ajv;\n}\n","import Ajv, { ErrorObject, ValidateFunction } from 'ajv';\nimport get from 'lodash/get';\nimport {\n createErrorHandler,\n CustomValidator,\n ErrorSchema,\n ErrorTransformer,\n FormContextType,\n getDefaultFormState,\n getUiOptions,\n PROPERTIES_KEY,\n RJSFSchema,\n RJSFValidationError,\n ROOT_SCHEMA_PREFIX,\n StrictRJSFSchema,\n toErrorList,\n toErrorSchema,\n UiSchema,\n unwrapErrorHandler,\n ValidationData,\n validationDataMerge,\n ValidatorType,\n withIdRefPrefix,\n} from '@rjsf/utils';\n\nimport { CustomValidatorOptionsType, Localizer } from './types';\nimport createAjvInstance from './createAjvInstance';\n\n/** `ValidatorType` implementation that uses the AJV 8 validation mechanism.\n */\nexport default class AJV8Validator<T = any, S extends StrictRJSFSchema = RJSFSchema, F extends FormContextType = any>\n implements ValidatorType<T, S, F>\n{\n /** The AJV instance to use for all validations\n *\n * @private\n */\n private ajv: Ajv;\n\n /** The Localizer function to use for localizing Ajv errors\n *\n * @private\n */\n readonly localizer?: Localizer;\n\n /** Constructs an `AJV8Validator` instance using the `options`\n *\n * @param options - The `CustomValidatorOptionsType` options that are used to create the AJV instance\n * @param [localizer] - If provided, is used to localize a list of Ajv `ErrorObject`s\n */\n constructor(options: CustomValidatorOptionsType, localizer?: Localizer) {\n const { additionalMetaSchemas, customFormats, ajvOptionsOverrides, ajvFormatOptions, AjvClass } = options;\n this.ajv = createAjvInstance(additionalMetaSchemas, customFormats, ajvOptionsOverrides, ajvFormatOptions, AjvClass);\n this.localizer = localizer;\n }\n\n /** Converts an `errorSchema` into a list of `RJSFValidationErrors`\n *\n * @param errorSchema - The `ErrorSchema` instance to convert\n * @param [fieldPath=[]] - The current field path, defaults to [] if not specified\n * @deprecated - Use the `toErrorList()` function provided by `@rjsf/utils` instead. This function will be removed in\n * the next major release.\n */\n toErrorList(errorSchema?: ErrorSchema<T>, fieldPath: string[] = []) {\n return toErrorList(errorSchema, fieldPath);\n }\n\n /** Transforming the error output from ajv to format used by @rjsf/utils.\n * At some point, components should be updated to support ajv.\n *\n * @param errors - The list of AJV errors to convert to `RJSFValidationErrors`\n * @param [uiSchema] - An optional uiSchema that is passed to `transformErrors` and `customValidate`\n * @protected\n */\n protected transformRJSFValidationErrors(\n errors: ErrorObject[] = [],\n uiSchema?: UiSchema<T, S, F>\n ): RJSFValidationError[] {\n return errors.map((e: ErrorObject) => {\n const { instancePath, keyword, params, schemaPath, parentSchema, ...rest } = e;\n let { message = '' } = rest;\n let property = instancePath.replace(/\\//g, '.');\n let stack = `${property} ${message}`.trim();\n\n if ('missingProperty' in params) {\n property = property ? `${property}.${params.missingProperty}` : params.missingProperty;\n const currentProperty: string = params.missingProperty;\n const uiSchemaTitle = getUiOptions(get(uiSchema, `${property.replace(/^\\./, '')}`)).title;\n\n if (uiSchemaTitle) {\n message = message.replace(currentProperty, uiSchemaTitle);\n } else {\n const parentSchemaTitle = get(parentSchema, [PROPERTIES_KEY, currentProperty, 'title']);\n\n if (parentSchemaTitle) {\n message = message.replace(currentProperty, parentSchemaTitle);\n }\n }\n\n stack = message;\n } else {\n const uiSchemaTitle = getUiOptions<T, S, F>(get(uiSchema, `${property.replace(/^\\./, '')}`)).title;\n\n if (uiSchemaTitle) {\n stack = `'${uiSchemaTitle}' ${message}`.trim();\n } else {\n const parentSchemaTitle = parentSchema?.title;\n\n if (parentSchemaTitle) {\n stack = `'${parentSchemaTitle}' ${message}`.trim();\n }\n }\n }\n\n // put data in expected format\n return {\n name: keyword,\n property,\n message,\n params, // specific to ajv\n stack,\n schemaPath,\n };\n });\n }\n\n /** Runs the pure validation of the `schema` and `formData` without any of the RJSF functionality. Provided for use\n * by the playground. Returns the `errors` from the validation\n *\n * @param schema - The schema against which to validate the form data * @param schema\n * @param formData - The form data to validate\n */\n rawValidation<Result = any>(schema: RJSFSchema, formData?: T): { errors?: Result[]; validationError?: Error } {\n let compilationError: Error | undefined = undefined;\n let compiledValidator: ValidateFunction | undefined;\n if (schema['$id']) {\n compiledValidator = this.ajv.getSchema(schema['$id']);\n }\n try {\n if (compiledValidator === undefined) {\n compiledValidator = this.ajv.compile(schema);\n }\n compiledValidator(formData);\n } catch (err) {\n compilationError = err as Error;\n }\n\n let errors;\n if (compiledValidator) {\n if (typeof this.localizer === 'function') {\n this.localizer(compiledValidator.errors);\n }\n errors = compiledValidator.errors || undefined;\n\n // Clear errors to prevent persistent errors, see #1104\n compiledValidator.errors = null;\n }\n\n return {\n errors: errors as unknown as Result[],\n validationError: compilationError,\n };\n }\n\n /** This function processes the `formData` with an optional user contributed `customValidate` function, which receives\n * the form data and a `errorHandler` function that will be used to add custom validation errors for each field. Also\n * supports a `transformErrors` function that will take the raw AJV validation errors, prior to custom validation and\n * transform them in what ever way it chooses.\n *\n * @param formData - The form data to validate\n * @param schema - The schema against which to validate the form data\n * @param [customValidate] - An optional function that is used to perform custom validation\n * @param [transformErrors] - An optional function that is used to transform errors after AJV validation\n * @param [uiSchema] - An optional uiSchema that is passed to `transformErrors` and `customValidate`\n */\n validateFormData(\n formData: T | undefined,\n schema: S,\n customValidate?: CustomValidator<T, S, F>,\n transformErrors?: ErrorTransformer<T, S, F>,\n uiSchema?: UiSchema<T, S, F>\n ): ValidationData<T> {\n const rawErrors = this.rawValidation<ErrorObject>(schema, formData);\n const { validationError: invalidSchemaError } = rawErrors;\n let errors = this.transformRJSFValidationErrors(rawErrors.errors, uiSchema);\n\n if (invalidSchemaError) {\n errors = [...errors, { stack: invalidSchemaError!.message }];\n }\n if (typeof transformErrors === 'function') {\n errors = transformErrors(errors, uiSchema);\n }\n\n let errorSchema = toErrorSchema<T>(errors);\n\n if (invalidSchemaError) {\n errorSchema = {\n ...errorSchema,\n $schema: {\n __errors: [invalidSchemaError!.message],\n },\n };\n }\n\n if (typeof customValidate !== 'function') {\n return { errors, errorSchema };\n }\n\n // Include form data with undefined values, which is required for custom validation.\n const newFormData = getDefaultFormState<T, S, F>(this, schema, formData, schema, true) as T;\n\n const errorHandler = customValidate(newFormData, createErrorHandler<T>(newFormData), uiSchema);\n const userErrorSchema = unwrapErrorHandler<T>(errorHandler);\n return validationDataMerge<T>({ errors, errorSchema }, userErrorSchema);\n }\n\n /** Validates data against a schema, returning true if the data is valid, or\n * false otherwise. If the schema is invalid, then this function will return\n * false.\n *\n * @param schema - The schema against which to validate the form data\n * @param formData - The form data to validate\n * @param rootSchema - The root schema used to provide $ref resolutions\n */\n isValid(schema: S, formData: T | undefined, rootSchema: S) {\n const rootSchemaId = rootSchema['$id'] ?? ROOT_SCHEMA_PREFIX;\n try {\n // add the rootSchema ROOT_SCHEMA_PREFIX as id.\n // then rewrite the schema ref's to point to the rootSchema\n // this accounts for the case where schema have references to models\n // that lives in the rootSchema but not in the schema in question.\n if (this.ajv.getSchema(rootSchemaId) === undefined) {\n this.ajv.addSchema(rootSchema, rootSchemaId);\n }\n const schemaWithIdRefPrefix = withIdRefPrefix<S>(schema) as S;\n let compiledValidator: ValidateFunction | undefined;\n if (schemaWithIdRefPrefix['$id']) {\n compiledValidator = this.ajv.getSchema(schemaWithIdRefPrefix['$id']);\n }\n if (compiledValidator === undefined) {\n compiledValidator = this.ajv.compile(schemaWithIdRefPrefix);\n }\n const result = compiledValidator(formData);\n return result as boolean;\n } catch (e) {\n console.warn('Error encountered compiling schema:', e);\n return false;\n } finally {\n // TODO: A function should be called if the root schema changes so we don't have to remove and recompile the schema every run.\n // make sure we remove the rootSchema from the global ajv instance\n this.ajv.removeSchema(rootSchemaId);\n }\n }\n}\n","import { FormContextType, RJSFSchema, StrictRJSFSchema, ValidatorType } from '@rjsf/utils';\n\nimport { CustomValidatorOptionsType, Localizer } from './types';\nimport AJV8Validator from './validator';\n\n/** Creates and returns a customized implementation of the `ValidatorType` with the given customization `options` if\n * provided.\n *\n * @param [options={}] - The `CustomValidatorOptionsType` options that are used to create the `ValidatorType` instance\n * @param [localizer] - If provided, is used to localize a list of Ajv `ErrorObject`s\n */\nexport default function customizeValidator<\n T = any,\n S extends StrictRJSFSchema = RJSFSchema,\n F extends FormContextType = any\n>(options: CustomValidatorOptionsType = {}, localizer?: Localizer): ValidatorType<T, S, F> {\n return new AJV8Validator<T, S, F>(options, localizer);\n}\n","import customizeValidator from './customizeValidator';\n\nexport { customizeValidator };\nexport * from './types';\n\nexport default customizeValidator();\n"],"names":["AJV_CONFIG","allErrors","multipleOfPrecision","strict","verbose","COLOR_FORMAT_REGEX","DATA_URL_FORMAT_REGEX","createAjvInstance","additionalMetaSchemas","customFormats","ajvOptionsOverrides","ajvFormatOptions","AjvClass","Ajv","ajv","_extends","addFormats","addFormat","addKeyword","ADDITIONAL_PROPERTY_FLAG","RJSF_ADDITONAL_PROPERTIES_FLAG","Array","isArray","addMetaSchema","isObject","Object","keys","forEach","formatName","AJV8Validator","options","localizer","_proto","prototype","toErrorList","errorSchema","fieldPath","transformRJSFValidationErrors","errors","uiSchema","map","e","instancePath","keyword","params","schemaPath","parentSchema","rest","_objectWithoutPropertiesLoose","_excluded","_rest$message","message","property","replace","stack","trim","missingProperty","currentProperty","uiSchemaTitle","getUiOptions","get","title","parentSchemaTitle","PROPERTIES_KEY","name","rawValidation","schema","formData","compilationError","undefined","compiledValidator","getSchema","compile","err","validationError","validateFormData","customValidate","transformErrors","rawErrors","invalidSchemaError","concat","toErrorSchema","$schema","__errors","newFormData","getDefaultFormState","errorHandler","createErrorHandler","userErrorSchema","unwrapErrorHandler","validationDataMerge","isValid","rootSchema","_rootSchema$$id","rootSchemaId","ROOT_SCHEMA_PREFIX","addSchema","schemaWithIdRefPrefix","withIdRefPrefix","result","console","warn","removeSchema","customizeValidator"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var r=require("lodash/
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var r=require("lodash/get"),e=require("@rjsf/utils"),a=require("ajv"),t=require("ajv-formats"),i=require("lodash/isObject");function o(r){return r&&"object"==typeof r&&"default"in r?r:{default:r}}var s=o(r),n=o(a),l=o(t),d=o(i);function c(){return c=Object.assign?Object.assign.bind():function(r){for(var e=1;e<arguments.length;e++){var a=arguments[e];for(var t in a)Object.prototype.hasOwnProperty.call(a,t)&&(r[t]=a[t])}return r},c.apply(this,arguments)}var u={allErrors:!0,multipleOfPrecision:8,strict:!1,verbose:!0},v=/^(#?([0-9A-Fa-f]{3}){1,2}\b|aqua|black|blue|fuchsia|gray|green|lime|maroon|navy|olive|orange|purple|red|silver|teal|white|yellow|(rgb\(\s*\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\b\s*,\s*\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\b\s*,\s*\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\b\s*\))|(rgb\(\s*(\d?\d%|100%)+\s*,\s*(\d?\d%|100%)+\s*,\s*(\d?\d%|100%)+\s*\)))$/,f=/^data:([a-z]+\/[a-z0-9-+.]+)?;(?:name=(.*);)?base64,(.*)$/,m=["instancePath","keyword","params","schemaPath","parentSchema"],h=function(){function r(r,a){this.ajv=void 0,this.localizer=void 0,this.ajv=function(r,a,t,i,o){void 0===t&&(t={}),void 0===o&&(o=n.default);var s=new o(c({},u,t));return i?l.default(s,i):!1!==i&&l.default(s),s.addFormat("data-url",f),s.addFormat("color",v),s.addKeyword(e.ADDITIONAL_PROPERTY_FLAG),s.addKeyword(e.RJSF_ADDITONAL_PROPERTIES_FLAG),Array.isArray(r)&&s.addMetaSchema(r),d.default(a)&&Object.keys(a).forEach((function(r){s.addFormat(r,a[r])})),s}(r.additionalMetaSchemas,r.customFormats,r.ajvOptionsOverrides,r.ajvFormatOptions,r.AjvClass),this.localizer=a}var a=r.prototype;return a.toErrorList=function(r,a){return void 0===a&&(a=[]),e.toErrorList(r,a)},a.transformRJSFValidationErrors=function(r,a){return void 0===r&&(r=[]),r.map((function(r){var t=r.instancePath,i=r.keyword,o=r.params,n=r.schemaPath,l=r.parentSchema,d=function(r,e){if(null==r)return{};var a,t,i={},o=Object.keys(r);for(t=0;t<o.length;t++)e.indexOf(a=o[t])>=0||(i[a]=r[a]);return i}(r,m).message,c=void 0===d?"":d,u=t.replace(/\//g,"."),v=(u+" "+c).trim();if("missingProperty"in o){var f=o.missingProperty,h=e.getUiOptions(s.default(a,""+(u=u?u+"."+o.missingProperty:o.missingProperty).replace(/^\./,""))).title;if(h)c=c.replace(f,h);else{var p=s.default(l,[e.PROPERTIES_KEY,f,"title"]);p&&(c=c.replace(f,p))}v=c}else{var y=e.getUiOptions(s.default(a,""+u.replace(/^\./,""))).title;if(y)v=("'"+y+"' "+c).trim();else{var g=null==l?void 0:l.title;g&&(v=("'"+g+"' "+c).trim())}}return{name:i,property:u,message:c,params:o,stack:v,schemaPath:n}}))},a.rawValidation=function(r,e){var a,t,i=void 0;r.$id&&(a=this.ajv.getSchema(r.$id));try{void 0===a&&(a=this.ajv.compile(r)),a(e)}catch(r){i=r}return a&&("function"==typeof this.localizer&&this.localizer(a.errors),t=a.errors||void 0,a.errors=null),{errors:t,validationError:i}},a.validateFormData=function(r,a,t,i,o){var s=this.rawValidation(a,r),n=s.validationError,l=this.transformRJSFValidationErrors(s.errors,o);n&&(l=[].concat(l,[{stack:n.message}])),"function"==typeof i&&(l=i(l,o));var d=e.toErrorSchema(l);if(n&&(d=c({},d,{$schema:{__errors:[n.message]}})),"function"!=typeof t)return{errors:l,errorSchema:d};var u=e.getDefaultFormState(this,a,r,a,!0),v=t(u,e.createErrorHandler(u),o),f=e.unwrapErrorHandler(v);return e.validationDataMerge({errors:l,errorSchema:d},f)},a.isValid=function(r,a,t){var i,o=null!=(i=t.$id)?i:e.ROOT_SCHEMA_PREFIX;try{void 0===this.ajv.getSchema(o)&&this.ajv.addSchema(t,o);var s,n=e.withIdRefPrefix(r);return n.$id&&(s=this.ajv.getSchema(n.$id)),void 0===s&&(s=this.ajv.compile(n)),s(a)}catch(r){return console.warn("Error encountered compiling schema:",r),!1}finally{this.ajv.removeSchema(o)}},r}();function p(r,e){return void 0===r&&(r={}),new h(r,e)}var y=p();exports.customizeValidator=p,exports.default=y;
|
|
2
2
|
//# sourceMappingURL=validator-ajv8.cjs.production.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validator-ajv8.cjs.production.min.js","sources":["../src/createAjvInstance.ts","../src/validator.ts","../src/customizeValidator.ts","../src/index.ts"],"sourcesContent":["import Ajv, { Options } from 'ajv';\nimport addFormats, { FormatsPluginOptions } from 'ajv-formats';\nimport isObject from 'lodash/isObject';\n\nimport { CustomValidatorOptionsType } from './types';\nimport { ADDITIONAL_PROPERTY_FLAG, RJSF_ADDITONAL_PROPERTIES_FLAG } from '@rjsf/utils';\n\nexport const AJV_CONFIG: Options = {\n allErrors: true,\n multipleOfPrecision: 8,\n strict: false,\n verbose: true,\n} as const;\nexport const COLOR_FORMAT_REGEX =\n /^(#?([0-9A-Fa-f]{3}){1,2}\\b|aqua|black|blue|fuchsia|gray|green|lime|maroon|navy|olive|orange|purple|red|silver|teal|white|yellow|(rgb\\(\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*,\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*,\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*\\))|(rgb\\(\\s*(\\d?\\d%|100%)+\\s*,\\s*(\\d?\\d%|100%)+\\s*,\\s*(\\d?\\d%|100%)+\\s*\\)))$/;\nexport const DATA_URL_FORMAT_REGEX = /^data:([a-z]+\\/[a-z0-9-+.]+)?;(?:name=(.*);)?base64,(.*)$/;\n\n/** Creates an Ajv version 8 implementation object with standard support for the 'color` and `data-url` custom formats.\n * If `additionalMetaSchemas` are provided then the Ajv instance is modified to add each of the meta schemas in the\n * list. If `customFormats` are provided then those additional formats are added to the list of supported formats. If\n * `ajvOptionsOverrides` are provided then they are spread on top of the default `AJV_CONFIG` options when constructing\n * the `Ajv` instance. With Ajv v8, the JSON Schema formats are not provided by default, but can be plugged in. By\n * default, all formats from the `ajv-formats` library are added. To disable this capability, set the `ajvFormatOptions`\n * parameter to `false`. Additionally, you can configure the `ajv-formats` by providing a custom set of\n * [format options](https://github.com/ajv-validator/ajv-formats) to the `ajvFormatOptions` parameter.\n *\n * @param [additionalMetaSchemas] - The list of additional meta schemas that the validator can access\n * @param [customFormats] - The set of additional custom formats that the validator will support\n * @param [ajvOptionsOverrides={}] - The set of validator config override options\n * @param [ajvFormatOptions] - The `ajv-format` options to use when adding formats to `ajv`; pass `false` to disable it\n * @param [AjvClass] - The `Ajv` class to use when creating the validator instance\n */\nexport default function createAjvInstance(\n additionalMetaSchemas?: CustomValidatorOptionsType['additionalMetaSchemas'],\n customFormats?: CustomValidatorOptionsType['customFormats'],\n ajvOptionsOverrides: CustomValidatorOptionsType['ajvOptionsOverrides'] = {},\n ajvFormatOptions?: FormatsPluginOptions | false,\n AjvClass: typeof Ajv = Ajv\n) {\n const ajv = new AjvClass({ ...AJV_CONFIG, ...ajvOptionsOverrides });\n if (ajvFormatOptions) {\n addFormats(ajv, ajvFormatOptions);\n } else if (ajvFormatOptions !== false) {\n addFormats(ajv);\n }\n\n // add custom formats\n ajv.addFormat('data-url', DATA_URL_FORMAT_REGEX);\n ajv.addFormat('color', COLOR_FORMAT_REGEX);\n\n // Add RJSF-specific additional properties keywords so Ajv doesn't report errors if strict is enabled.\n ajv.addKeyword(ADDITIONAL_PROPERTY_FLAG);\n ajv.addKeyword(RJSF_ADDITONAL_PROPERTIES_FLAG);\n\n // add more schemas to validate against\n if (Array.isArray(additionalMetaSchemas)) {\n ajv.addMetaSchema(additionalMetaSchemas);\n }\n\n // add more custom formats to validate against\n if (isObject(customFormats)) {\n Object.keys(customFormats).forEach((formatName) => {\n ajv.addFormat(formatName, customFormats[formatName]);\n });\n }\n\n return ajv;\n}\n","import Ajv, { ErrorObject, ValidateFunction } from 'ajv';\nimport toPath from 'lodash/toPath';\nimport isPlainObject from 'lodash/isPlainObject';\nimport clone from 'lodash/clone';\nimport {\n CustomValidator,\n ERRORS_KEY,\n ErrorSchema,\n ErrorSchemaBuilder,\n ErrorTransformer,\n FieldValidation,\n FormContextType,\n FormValidation,\n GenericObjectType,\n getDefaultFormState,\n mergeValidationData,\n REF_KEY,\n RJSFSchema,\n RJSFValidationError,\n StrictRJSFSchema,\n UiSchema,\n ValidationData,\n ValidatorType,\n PROPERTIES_KEY,\n getUiOptions,\n} from '@rjsf/utils';\nimport get from 'lodash/get';\n\nimport { CustomValidatorOptionsType, Localizer } from './types';\nimport createAjvInstance from './createAjvInstance';\n\nconst ROOT_SCHEMA_PREFIX = '__rjsf_rootSchema';\n\n/** `ValidatorType` implementation that uses the AJV 8 validation mechanism.\n */\nexport default class AJV8Validator<T = any, S extends StrictRJSFSchema = RJSFSchema, F extends FormContextType = any>\n implements ValidatorType<T, S, F>\n{\n /** The AJV instance to use for all validations\n *\n * @private\n */\n private ajv: Ajv;\n\n /** The Localizer function to use for localizing Ajv errors\n *\n * @private\n */\n readonly localizer?: Localizer;\n\n /** Constructs an `AJV8Validator` instance using the `options`\n *\n * @param options - The `CustomValidatorOptionsType` options that are used to create the AJV instance\n * @param [localizer] - If provided, is used to localize a list of Ajv `ErrorObject`s\n */\n constructor(options: CustomValidatorOptionsType, localizer?: Localizer) {\n const { additionalMetaSchemas, customFormats, ajvOptionsOverrides, ajvFormatOptions, AjvClass } = options;\n this.ajv = createAjvInstance(additionalMetaSchemas, customFormats, ajvOptionsOverrides, ajvFormatOptions, AjvClass);\n this.localizer = localizer;\n }\n\n /** Transforms a ajv validation errors list:\n * [\n * {property: '.level1.level2[2].level3', message: 'err a'},\n * {property: '.level1.level2[2].level3', message: 'err b'},\n * {property: '.level1.level2[4].level3', message: 'err b'},\n * ]\n * Into an error tree:\n * {\n * level1: {\n * level2: {\n * 2: {level3: {errors: ['err a', 'err b']}},\n * 4: {level3: {errors: ['err b']}},\n * }\n * }\n * };\n *\n * @param errors - The list of RJSFValidationError objects\n * @private\n */\n private toErrorSchema(errors: RJSFValidationError[]): ErrorSchema<T> {\n const builder = new ErrorSchemaBuilder<T>();\n if (errors.length) {\n errors.forEach((error) => {\n const { property, message } = error;\n const path = toPath(property);\n\n // If the property is at the root (.level1) then toPath creates\n // an empty array element at the first index. Remove it.\n if (path.length > 0 && path[0] === '') {\n path.splice(0, 1);\n }\n if (message) {\n builder.addErrors(message, path);\n }\n });\n }\n return builder.ErrorSchema;\n }\n\n /** Converts an `errorSchema` into a list of `RJSFValidationErrors`\n *\n * @param errorSchema - The `ErrorSchema` instance to convert\n * @param [fieldPath=[]] - The current field path, defaults to [] if not specified\n */\n toErrorList(errorSchema?: ErrorSchema<T>, fieldPath: string[] = []) {\n if (!errorSchema) {\n return [];\n }\n let errorList: RJSFValidationError[] = [];\n if (ERRORS_KEY in errorSchema) {\n errorList = errorList.concat(\n errorSchema[ERRORS_KEY]!.map((message: string) => {\n const property = `.${fieldPath.join('.')}`;\n return {\n property,\n message,\n stack: `${property} ${message}`,\n };\n })\n );\n }\n return Object.keys(errorSchema).reduce((acc, key) => {\n if (key !== ERRORS_KEY) {\n const childSchema = (errorSchema as GenericObjectType)[key];\n if (isPlainObject(childSchema)) {\n acc = acc.concat(this.toErrorList(childSchema, [...fieldPath, key]));\n }\n }\n return acc;\n }, errorList);\n }\n\n /** Given a `formData` object, recursively creates a `FormValidation` error handling structure around it\n *\n * @param formData - The form data around which the error handler is created\n * @private\n */\n private createErrorHandler(formData: T): FormValidation<T> {\n const handler: FieldValidation = {\n // We store the list of errors for this node in a property named __errors\n // to avoid name collision with a possible sub schema field named\n // 'errors' (see `utils.toErrorSchema`).\n __errors: [],\n addError(message: string) {\n this.__errors!.push(message);\n },\n };\n if (Array.isArray(formData)) {\n return formData.reduce((acc, value, key) => {\n return { ...acc, [key]: this.createErrorHandler(value) };\n }, handler);\n }\n if (isPlainObject(formData)) {\n const formObject: GenericObjectType = formData as GenericObjectType;\n return Object.keys(formObject).reduce((acc, key) => {\n return { ...acc, [key]: this.createErrorHandler(formObject[key]) };\n }, handler as FormValidation<T>);\n }\n return handler as FormValidation<T>;\n }\n\n /** Unwraps the `errorHandler` structure into the associated `ErrorSchema`, stripping the `addError` functions from it\n *\n * @param errorHandler - The `FormValidation` error handling structure\n * @private\n */\n private unwrapErrorHandler(errorHandler: FormValidation<T>): ErrorSchema<T> {\n return Object.keys(errorHandler).reduce((acc, key) => {\n if (key === 'addError') {\n return acc;\n } else {\n const childSchema = (errorHandler as GenericObjectType)[key];\n if (isPlainObject(childSchema)) {\n return {\n ...acc,\n [key]: this.unwrapErrorHandler(childSchema),\n };\n }\n return { ...acc, [key]: childSchema };\n }\n }, {} as ErrorSchema<T>);\n }\n\n /** Transforming the error output from ajv to format used by @rjsf/utils.\n * At some point, components should be updated to support ajv.\n *\n * @param errors - The list of AJV errors to convert to `RJSFValidationErrors`\n * @protected\n */\n protected transformRJSFValidationErrors(\n errors: ErrorObject[] = [],\n uiSchema?: UiSchema<T, S, F>\n ): RJSFValidationError[] {\n return errors.map((e: ErrorObject) => {\n const { instancePath, keyword, params, schemaPath, parentSchema, ...rest } = e;\n let { message = '' } = rest;\n let property = instancePath.replace(/\\//g, '.');\n let stack = `${property} ${message}`.trim();\n\n if ('missingProperty' in params) {\n property = property ? `${property}.${params.missingProperty}` : params.missingProperty;\n const currentProperty: string = params.missingProperty;\n const uiSchemaTitle = getUiOptions(get(uiSchema, `${property.replace(/^\\./, '')}`)).title;\n\n if (uiSchemaTitle) {\n message = message.replace(currentProperty, uiSchemaTitle);\n } else {\n const parentSchemaTitle = get(parentSchema, [PROPERTIES_KEY, currentProperty, 'title']);\n\n if (parentSchemaTitle) {\n message = message.replace(currentProperty, parentSchemaTitle);\n }\n }\n\n stack = message;\n } else {\n const uiSchemaTitle = getUiOptions(get(uiSchema, `${property.replace(/^\\./, '')}`)).title;\n\n if (uiSchemaTitle) {\n stack = `'${uiSchemaTitle}' ${message}`.trim();\n } else {\n const parentSchemaTitle = parentSchema?.title;\n\n if (parentSchemaTitle) {\n stack = `'${parentSchemaTitle}' ${message}`.trim();\n }\n }\n }\n\n // put data in expected format\n return {\n name: keyword,\n property,\n message,\n params, // specific to ajv\n stack,\n schemaPath,\n };\n });\n }\n\n /** Runs the pure validation of the `schema` and `formData` without any of the RJSF functionality. Provided for use\n * by the playground. Returns the `errors` from the validation\n *\n * @param schema - The schema against which to validate the form data * @param schema\n * @param formData - The form data to validate\n */\n rawValidation<Result = any>(schema: RJSFSchema, formData?: T): { errors?: Result[]; validationError?: Error } {\n let compilationError: Error | undefined = undefined;\n let compiledValidator: ValidateFunction | undefined;\n if (schema['$id']) {\n compiledValidator = this.ajv.getSchema(schema['$id']);\n }\n try {\n if (compiledValidator === undefined) {\n compiledValidator = this.ajv.compile(schema);\n }\n compiledValidator(formData);\n } catch (err) {\n compilationError = err as Error;\n }\n\n let errors;\n if (compiledValidator) {\n if (typeof this.localizer === 'function') {\n this.localizer(compiledValidator.errors);\n }\n errors = compiledValidator.errors || undefined;\n\n // Clear errors to prevent persistent errors, see #1104\n compiledValidator.errors = null;\n }\n\n return {\n errors: errors as unknown as Result[],\n validationError: compilationError,\n };\n }\n\n /** This function processes the `formData` with an optional user contributed `customValidate` function, which receives\n * the form data and a `errorHandler` function that will be used to add custom validation errors for each field. Also\n * supports a `transformErrors` function that will take the raw AJV validation errors, prior to custom validation and\n * transform them in what ever way it chooses.\n *\n * @param formData - The form data to validate\n * @param schema - The schema against which to validate the form data\n * @param [customValidate] - An optional function that is used to perform custom validation\n * @param [transformErrors] - An optional function that is used to transform errors after AJV validation\n * @param [uiSchema] - An optional uiSchema that is passed to `transformErrors` and `customValidate`\n */\n validateFormData(\n formData: T | undefined,\n schema: S,\n customValidate?: CustomValidator<T, S, F>,\n transformErrors?: ErrorTransformer<T, S, F>,\n uiSchema?: UiSchema<T, S, F>\n ): ValidationData<T> {\n const rawErrors = this.rawValidation<ErrorObject>(schema, formData);\n const { validationError: invalidSchemaError } = rawErrors;\n let errors = this.transformRJSFValidationErrors(rawErrors.errors, uiSchema);\n\n if (invalidSchemaError) {\n errors = [...errors, { stack: invalidSchemaError!.message }];\n }\n if (typeof transformErrors === 'function') {\n errors = transformErrors(errors, uiSchema);\n }\n\n let errorSchema = this.toErrorSchema(errors);\n\n if (invalidSchemaError) {\n errorSchema = {\n ...errorSchema,\n $schema: {\n __errors: [invalidSchemaError!.message],\n },\n };\n }\n\n if (typeof customValidate !== 'function') {\n return { errors, errorSchema };\n }\n\n // Include form data with undefined values, which is required for custom validation.\n const newFormData = getDefaultFormState<T, S, F>(this, schema, formData, schema, true) as T;\n\n const errorHandler = customValidate(newFormData, this.createErrorHandler(newFormData), uiSchema);\n const userErrorSchema = this.unwrapErrorHandler(errorHandler);\n return mergeValidationData<T, S, F>(this, { errors, errorSchema }, userErrorSchema);\n }\n\n /** Takes a `node` object and transforms any contained `$ref` node variables with a prefix, recursively calling\n * `withIdRefPrefix` for any other elements.\n *\n * @param node - The object node to which a ROOT_SCHEMA_PREFIX is added when a REF_KEY is part of it\n * @private\n */\n private withIdRefPrefixObject(node: S) {\n for (const key in node) {\n const realObj: GenericObjectType = node;\n const value = realObj[key];\n if (key === REF_KEY && typeof value === 'string' && value.startsWith('#')) {\n realObj[key] = ROOT_SCHEMA_PREFIX + value;\n } else {\n realObj[key] = this.withIdRefPrefix(value);\n }\n }\n return node;\n }\n\n /** Takes a `node` object list and transforms any contained `$ref` node variables with a prefix, recursively calling\n * `withIdRefPrefix` for any other elements.\n *\n * @param node - The list of object nodes to which a ROOT_SCHEMA_PREFIX is added when a REF_KEY is part of it\n * @private\n */\n private withIdRefPrefixArray(node: S[]): S[] {\n for (let i = 0; i < node.length; i++) {\n node[i] = this.withIdRefPrefix(node[i]) as S;\n }\n return node;\n }\n\n /** Validates data against a schema, returning true if the data is valid, or\n * false otherwise. If the schema is invalid, then this function will return\n * false.\n *\n * @param schema - The schema against which to validate the form data\n * @param formData - The form data to validate\n * @param rootSchema - The root schema used to provide $ref resolutions\n */\n isValid(schema: S, formData: T | undefined, rootSchema: S) {\n const rootSchemaId = rootSchema['$id'] ?? ROOT_SCHEMA_PREFIX;\n try {\n // add the rootSchema ROOT_SCHEMA_PREFIX as id.\n // then rewrite the schema ref's to point to the rootSchema\n // this accounts for the case where schema have references to models\n // that lives in the rootSchema but not in the schema in question.\n if (this.ajv.getSchema(rootSchemaId) === undefined) {\n this.ajv.addSchema(rootSchema, rootSchemaId);\n }\n const schemaWithIdRefPrefix = this.withIdRefPrefix(schema) as S;\n let compiledValidator: ValidateFunction | undefined;\n if (schemaWithIdRefPrefix['$id']) {\n compiledValidator = this.ajv.getSchema(schemaWithIdRefPrefix['$id']);\n }\n if (compiledValidator === undefined) {\n compiledValidator = this.ajv.compile(schemaWithIdRefPrefix);\n }\n const result = compiledValidator(formData);\n return result as boolean;\n } catch (e) {\n console.warn('Error encountered compiling schema:', e);\n return false;\n } finally {\n // TODO: A function should be called if the root schema changes so we don't have to remove and recompile the schema every run.\n // make sure we remove the rootSchema from the global ajv instance\n this.ajv.removeSchema(rootSchemaId);\n }\n }\n\n /** Recursively prefixes all $ref's in a schema with `ROOT_SCHEMA_PREFIX`\n * This is used in isValid to make references to the rootSchema\n *\n * @param schemaNode - The object node to which a ROOT_SCHEMA_PREFIX is added when a REF_KEY is part of it\n * @protected\n */\n protected withIdRefPrefix(schemaNode: S | S[]): S | S[] {\n if (Array.isArray(schemaNode)) {\n return this.withIdRefPrefixArray([...schemaNode]);\n }\n if (isPlainObject(schemaNode)) {\n return this.withIdRefPrefixObject(clone<S>(schemaNode));\n }\n return schemaNode;\n }\n}\n","import { FormContextType, RJSFSchema, StrictRJSFSchema, ValidatorType } from '@rjsf/utils';\n\nimport { CustomValidatorOptionsType, Localizer } from './types';\nimport AJV8Validator from './validator';\n\n/** Creates and returns a customized implementation of the `ValidatorType` with the given customization `options` if\n * provided.\n *\n * @param [options={}] - The `CustomValidatorOptionsType` options that are used to create the `ValidatorType` instance\n * @param [localizer] - If provided, is used to localize a list of Ajv `ErrorObject`s\n */\nexport default function customizeValidator<\n T = any,\n S extends StrictRJSFSchema = RJSFSchema,\n F extends FormContextType = any\n>(options: CustomValidatorOptionsType = {}, localizer?: Localizer): ValidatorType<T, S, F> {\n return new AJV8Validator<T, S, F>(options, localizer);\n}\n","import customizeValidator from './customizeValidator';\n\nexport { customizeValidator };\nexport * from './types';\n\nexport default customizeValidator();\n"],"names":["AJV_CONFIG","allErrors","multipleOfPrecision","strict","verbose","COLOR_FORMAT_REGEX","DATA_URL_FORMAT_REGEX","AJV8Validator","options","localizer","this","ajv","additionalMetaSchemas","customFormats","ajvOptionsOverrides","ajvFormatOptions","AjvClass","Ajv","_extends","addFormats","addFormat","addKeyword","ADDITIONAL_PROPERTY_FLAG","RJSF_ADDITONAL_PROPERTIES_FLAG","Array","isArray","addMetaSchema","isObject","Object","keys","forEach","formatName","createAjvInstance","_proto","prototype","toErrorSchema","errors","builder","ErrorSchemaBuilder","length","error","message","path","toPath","property","splice","addErrors","ErrorSchema","toErrorList","errorSchema","fieldPath","_this","errorList","ERRORS_KEY","concat","map","join","stack","reduce","acc","key","childSchema","isPlainObject","createErrorHandler","formData","_this2","handler","__errors","addError","push","value","_extends2","formObject","_extends3","unwrapErrorHandler","errorHandler","_this3","_extends5","_extends4","transformRJSFValidationErrors","uiSchema","e","instancePath","keyword","params","schemaPath","parentSchema","_rest$message","_objectWithoutPropertiesLoose","_excluded","replace","trim","currentProperty","missingProperty","uiSchemaTitle","getUiOptions","get","title","parentSchemaTitle","PROPERTIES_KEY","name","rawValidation","schema","compiledValidator","compilationError","undefined","getSchema","compile","err","validationError","validateFormData","customValidate","transformErrors","rawErrors","invalidSchemaError","$schema","newFormData","getDefaultFormState","userErrorSchema","mergeValidationData","withIdRefPrefixObject","node","REF_KEY","startsWith","withIdRefPrefix","withIdRefPrefixArray","i","isValid","rootSchema","_rootSchema$$id","rootSchemaId","addSchema","schemaWithIdRefPrefix","console","warn","removeSchema","schemaNode","clone","customizeValidator","index"],"mappings":"wnBAOO,IAAMA,EAAsB,CACjCC,WAAW,EACXC,oBAAqB,EACrBC,QAAQ,EACRC,SAAS,GAEEC,EACX,6YACWC,EAAwB,8HCoBhBC,EAAa,WAoBhC,SAAAA,EAAYC,EAAqCC,GAjBjDC,KAIQC,SAAG,EAEXD,KAISD,eAAS,EAShBC,KAAKC,IDzBe,SACtBC,EACAC,EACAC,EACAC,EACAC,YAFAF,IAAAA,EAAyE,CAAA,YAEzEE,IAAAA,EAAuBC,EAAAA,SAEvB,IAAMN,EAAM,IAAIK,EAAQE,EAAMlB,CAAAA,EAAAA,EAAec,IA2B7C,OA1BIC,EACFI,UAAWR,EAAKI,IACc,IAArBA,GACTI,EAAU,QAACR,GAIbA,EAAIS,UAAU,WAAYd,GAC1BK,EAAIS,UAAU,QAASf,GAGvBM,EAAIU,WAAWC,EAAAA,0BACfX,EAAIU,WAAWE,EAAAA,gCAGXC,MAAMC,QAAQb,IAChBD,EAAIe,cAAcd,GAIhBe,EAAAA,QAASd,IACXe,OAAOC,KAAKhB,GAAeiB,SAAQ,SAACC,GAClCpB,EAAIS,UAAUW,EAAYlB,EAAckB,GAC1C,IAGKpB,CACT,CCVeqB,CADuFxB,EAA1FI,sBAA0FJ,EAAnEK,cAAmEL,EAApDM,oBAAoDN,EAA/BO,iBAA+BP,EAAbQ,UAErFN,KAAKD,UAAYA,CACnB,CAEA,IAAAwB,EAAA1B,EAAA2B,UAmWC,OAnWDD,EAmBQE,cAAA,SAAcC,GACpB,IAAMC,EAAU,IAAIC,EAAAA,mBAgBpB,OAfIF,EAAOG,QACTH,EAAON,SAAQ,SAACU,GACd,IAAkBC,EAAYD,EAAZC,QACZC,EAAOC,UADiBH,EAAtBI,UAKJF,EAAKH,OAAS,GAAiB,KAAZG,EAAK,IAC1BA,EAAKG,OAAO,EAAG,GAEbJ,GACFJ,EAAQS,UAAUL,EAASC,EAE/B,IAEKL,EAAQU,WACjB,EAEAd,EAKAe,YAAA,SAAYC,EAA8BC,GAAwB,IAAAC,EAAAzC,KAChE,QADwC,IAAAwC,IAAAA,EAAsB,KACzDD,EACH,MAAO,GAET,IAAIG,EAAmC,GAavC,OAZIC,EAAAA,cAAcJ,IAChBG,EAAYA,EAAUE,OACpBL,EAAYI,EAAAA,YAAaE,KAAI,SAACd,GAC5B,IAAMG,EAAeM,IAAAA,EAAUM,KAAK,KACpC,MAAO,CACLZ,SAAAA,EACAH,QAAAA,EACAgB,MAAUb,EAAYH,IAAAA,EAEzB,MAGEb,OAAOC,KAAKoB,GAAaS,QAAO,SAACC,EAAKC,GAC3C,GAAIA,IAAQP,EAAAA,WAAY,CACtB,IAAMQ,EAAeZ,EAAkCW,GACnDE,EAAAA,QAAcD,KAChBF,EAAMA,EAAIL,OAAOH,EAAKH,YAAYa,KAAWP,OAAMJ,EAAWU,CAAAA,MAEjE,CACD,OAAOD,CACR,GAAEP,EACL,EAEAnB,EAKQ8B,mBAAA,SAAmBC,GAAW,IAAAC,EAAAvD,KAC9BwD,EAA2B,CAI/BC,SAAU,GACVC,SAAQ,SAAC3B,GACP/B,KAAKyD,SAAUE,KAAK5B,EACtB,GAEF,GAAIjB,MAAMC,QAAQuC,GAChB,OAAOA,EAASN,QAAO,SAACC,EAAKW,EAAOV,GAAO,IAAAW,EACzC,OAAArD,EAAYyC,CAAAA,EAAAA,IAAGY,MAAGX,GAAMK,EAAKF,mBAAmBO,GAAMC,GACvD,GAAEL,GAEL,GAAIJ,EAAAA,QAAcE,GAAW,CAC3B,IAAMQ,EAAgCR,EACtC,OAAOpC,OAAOC,KAAK2C,GAAYd,QAAO,SAACC,EAAKC,GAAO,IAAAa,EACjD,OAAAvD,KAAYyC,IAAGc,EAAAA,CAAAA,GAAGb,GAAMK,EAAKF,mBAAmBS,EAAWZ,IAAKa,GACjE,GAAEP,EACJ,CACD,OAAOA,CACT,EAEAjC,EAKQyC,mBAAA,SAAmBC,GAA+B,IAAAC,EAAAlE,KACxD,OAAOkB,OAAOC,KAAK8C,GAAcjB,QAAO,SAACC,EAAKC,GAC5C,GAAY,aAARA,EACF,OAAOD,EACF,IAAAkB,EAE2BC,EAD1BjB,EAAec,EAAmCf,GACxD,OAAIE,EAAAA,QAAcD,GAChB3C,EACKyC,CAAAA,EAAAA,IAAGmB,MACLlB,GAAMgB,EAAKF,mBAAmBb,GAAYiB,IAG/C5D,EAAA,CAAA,EAAYyC,IAAGkB,EAAA,CAAA,GAAGjB,GAAMC,EAAWgB,GAEtC,GAAE,CAAoB,EACzB,EAEA5C,EAMU8C,8BAAA,SACR3C,EACA4C,GAEA,YAHA,IAAA5C,IAAAA,EAAwB,IAGjBA,EAAOmB,KAAI,SAAC0B,GACjB,IAAQC,EAAqED,EAArEC,aAAcC,EAAuDF,EAAvDE,QAASC,EAA8CH,EAA9CG,OAAQC,EAAsCJ,EAAtCI,WAAYC,EAA0BL,EAA1BK,aACnDC,oIADwEC,CAAKP,EAACQ,GACxEhD,QAAAA,OAAU,IAAH8C,EAAG,GAAEA,EACd3C,EAAWsC,EAAaQ,QAAQ,MAAO,KACvCjC,GAAWb,MAAYH,GAAUkD,OAErC,GAAI,oBAAqBP,EAAQ,CAE/B,IAAMQ,EAA0BR,EAAOS,gBACjCC,EAAgBC,EAAAA,aAAaC,EAAG,QAAChB,EAAapC,IAFpDA,EAAWA,EAAcA,EAAQ,IAAIwC,EAAOS,gBAAoBT,EAAOS,iBAEVH,QAAQ,MAAO,MAAQO,MAEpF,GAAIH,EACFrD,EAAUA,EAAQiD,QAAQE,EAAiBE,OACtC,CACL,IAAMI,EAAoBF,EAAAA,QAAIV,EAAc,CAACa,EAAAA,eAAgBP,EAAiB,UAE1EM,IACFzD,EAAUA,EAAQiD,QAAQE,EAAiBM,GAE9C,CAEDzC,EAAQhB,CACT,KAAM,CACL,IAAMqD,EAAgBC,EAAAA,aAAaC,EAAG,QAAChB,EAAapC,GAAAA,EAAS8C,QAAQ,MAAO,MAAQO,MAEpF,GAAIH,EACFrC,GAAYqC,IAAAA,OAAkBrD,GAAUkD,WACnC,CACL,IAAMO,EAAoBZ,aAAAA,EAAAA,EAAcW,MAEpCC,IACFzC,GAAYyC,IAAAA,OAAsBzD,GAAUkD,OAE/C,CACF,CAGD,MAAO,CACLS,KAAMjB,EACNvC,SAAAA,EACAH,QAAAA,EACA2C,OAAAA,EACA3B,MAAAA,EACA4B,WAAAA,EAEJ,GACF,EAEApD,EAMAoE,cAAA,SAA4BC,EAAoBtC,GAC9C,IACIuC,EAaAnE,EAdAoE,OAAsCC,EAEtCH,EAAY,MACdC,EAAoB7F,KAAKC,IAAI+F,UAAUJ,EAAY,MAErD,SAC4BG,IAAtBF,IACFA,EAAoB7F,KAAKC,IAAIgG,QAAQL,IAEvCC,EAAkBvC,EAGnB,CAFC,MAAO4C,GACPJ,EAAmBI,CACpB,CAaD,OAVIL,IAC4B,mBAAnB7F,KAAKD,WACdC,KAAKD,UAAU8F,EAAkBnE,QAEnCA,EAASmE,EAAkBnE,aAAUqE,EAGrCF,EAAkBnE,OAAS,MAGtB,CACLA,OAAQA,EACRyE,gBAAiBL,EAErB,EAEAvE,EAWA6E,iBAAA,SACE9C,EACAsC,EACAS,EACAC,EACAhC,GAEA,IAAMiC,EAAYvG,KAAK2F,cAA2BC,EAAQtC,GACjCkD,EAAuBD,EAAxCJ,gBACJzE,EAAS1B,KAAKqE,8BAA8BkC,EAAU7E,OAAQ4C,GAE9DkC,IACF9E,EAAMkB,GAAAA,OAAOlB,EAAQ,CAAA,CAAEqB,MAAOyD,EAAoBzE,YAErB,mBAApBuE,IACT5E,EAAS4E,EAAgB5E,EAAQ4C,IAGnC,IAAI/B,EAAcvC,KAAKyB,cAAcC,GAWrC,GATI8E,IACFjE,EAAW/B,EAAA,CAAA,EACN+B,EAAW,CACdkE,QAAS,CACPhD,SAAU,CAAC+C,EAAoBzE,aAKP,mBAAnBsE,EACT,MAAO,CAAE3E,OAAAA,EAAQa,YAAAA,GAInB,IAAMmE,EAAcC,EAAAA,oBAA6B3G,KAAM4F,EAAQtC,EAAUsC,GAAQ,GAE3E3B,EAAeoC,EAAeK,EAAa1G,KAAKqD,mBAAmBqD,GAAcpC,GACjFsC,EAAkB5G,KAAKgE,mBAAmBC,GAChD,OAAO4C,EAAAA,oBAA6B7G,KAAM,CAAE0B,OAAAA,EAAQa,YAAAA,GAAeqE,EACrE,EAEArF,EAMQuF,sBAAA,SAAsBC,GAC5B,IAAK,IAAM7D,KAAO6D,EAAM,CACtB,IACMnD,EAD6BmD,EACb7D,GADa6D,EAGzB7D,GADNA,IAAQ8D,EAAOA,SAAqB,iBAAVpD,GAAsBA,EAAMqD,WAAW,KAvThD,oBAwTiBrD,EAErB5D,KAAKkH,gBAAgBtD,EAEvC,CACD,OAAOmD,CACT,EAEAxF,EAMQ4F,qBAAA,SAAqBJ,GAC3B,IAAK,IAAIK,EAAI,EAAGA,EAAIL,EAAKlF,OAAQuF,IAC/BL,EAAKK,GAAKpH,KAAKkH,gBAAgBH,EAAKK,IAEtC,OAAOL,CACT,EAEAxF,EAQA8F,QAAA,SAAQzB,EAAWtC,EAAyBgE,GAAa,IAAAC,EACjDC,EAAgC,OAApBD,EAAGD,EAAgB,KAACC,EAtVf,oBAuVvB,SAK2CxB,IAArC/F,KAAKC,IAAI+F,UAAUwB,IACrBxH,KAAKC,IAAIwH,UAAUH,EAAYE,GAEjC,IACI3B,EADE6B,EAAwB1H,KAAKkH,gBAAgBtB,GASnD,OAPI8B,EAA2B,MAC7B7B,EAAoB7F,KAAKC,IAAI+F,UAAU0B,EAA2B,WAE1C3B,IAAtBF,IACFA,EAAoB7F,KAAKC,IAAIgG,QAAQyB,IAExB7B,EAAkBvC,EASlC,CAPC,MAAOiB,GAEP,OADAoD,QAAQC,KAAK,sCAAuCrD,IAC7C,CACR,CAAS,QAGRvE,KAAKC,IAAI4H,aAAaL,EACvB,CACH,EAEAjG,EAMU2F,gBAAA,SAAgBY,GACxB,OAAIhH,MAAMC,QAAQ+G,GACT9H,KAAKmH,wBAAoBvE,OAAKkF,IAEnC1E,EAAAA,QAAc0E,GACT9H,KAAK8G,sBAAsBiB,UAASD,IAEtCA,GACRjI,CAAA,CA7X+B,GCxBV,SAAAmI,EAItBlI,EAA0CC,GAC1C,YADsC,IAAtCD,IAAAA,EAAsC,CAAA,GAC/B,IAAID,EAAuBC,EAASC,EAC7C,CCZA,IAAAkI,EAAeD"}
|
|
1
|
+
{"version":3,"file":"validator-ajv8.cjs.production.min.js","sources":["../src/createAjvInstance.ts","../src/validator.ts","../src/customizeValidator.ts","../src/index.ts"],"sourcesContent":["import Ajv, { Options } from 'ajv';\nimport addFormats, { FormatsPluginOptions } from 'ajv-formats';\nimport isObject from 'lodash/isObject';\n\nimport { CustomValidatorOptionsType } from './types';\nimport { ADDITIONAL_PROPERTY_FLAG, RJSF_ADDITONAL_PROPERTIES_FLAG } from '@rjsf/utils';\n\nexport const AJV_CONFIG: Options = {\n allErrors: true,\n multipleOfPrecision: 8,\n strict: false,\n verbose: true,\n} as const;\nexport const COLOR_FORMAT_REGEX =\n /^(#?([0-9A-Fa-f]{3}){1,2}\\b|aqua|black|blue|fuchsia|gray|green|lime|maroon|navy|olive|orange|purple|red|silver|teal|white|yellow|(rgb\\(\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*,\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*,\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*\\))|(rgb\\(\\s*(\\d?\\d%|100%)+\\s*,\\s*(\\d?\\d%|100%)+\\s*,\\s*(\\d?\\d%|100%)+\\s*\\)))$/;\nexport const DATA_URL_FORMAT_REGEX = /^data:([a-z]+\\/[a-z0-9-+.]+)?;(?:name=(.*);)?base64,(.*)$/;\n\n/** Creates an Ajv version 8 implementation object with standard support for the 'color` and `data-url` custom formats.\n * If `additionalMetaSchemas` are provided then the Ajv instance is modified to add each of the meta schemas in the\n * list. If `customFormats` are provided then those additional formats are added to the list of supported formats. If\n * `ajvOptionsOverrides` are provided then they are spread on top of the default `AJV_CONFIG` options when constructing\n * the `Ajv` instance. With Ajv v8, the JSON Schema formats are not provided by default, but can be plugged in. By\n * default, all formats from the `ajv-formats` library are added. To disable this capability, set the `ajvFormatOptions`\n * parameter to `false`. Additionally, you can configure the `ajv-formats` by providing a custom set of\n * [format options](https://github.com/ajv-validator/ajv-formats) to the `ajvFormatOptions` parameter.\n *\n * @param [additionalMetaSchemas] - The list of additional meta schemas that the validator can access\n * @param [customFormats] - The set of additional custom formats that the validator will support\n * @param [ajvOptionsOverrides={}] - The set of validator config override options\n * @param [ajvFormatOptions] - The `ajv-format` options to use when adding formats to `ajv`; pass `false` to disable it\n * @param [AjvClass] - The `Ajv` class to use when creating the validator instance\n */\nexport default function createAjvInstance(\n additionalMetaSchemas?: CustomValidatorOptionsType['additionalMetaSchemas'],\n customFormats?: CustomValidatorOptionsType['customFormats'],\n ajvOptionsOverrides: CustomValidatorOptionsType['ajvOptionsOverrides'] = {},\n ajvFormatOptions?: FormatsPluginOptions | false,\n AjvClass: typeof Ajv = Ajv\n) {\n const ajv = new AjvClass({ ...AJV_CONFIG, ...ajvOptionsOverrides });\n if (ajvFormatOptions) {\n addFormats(ajv, ajvFormatOptions);\n } else if (ajvFormatOptions !== false) {\n addFormats(ajv);\n }\n\n // add custom formats\n ajv.addFormat('data-url', DATA_URL_FORMAT_REGEX);\n ajv.addFormat('color', COLOR_FORMAT_REGEX);\n\n // Add RJSF-specific additional properties keywords so Ajv doesn't report errors if strict is enabled.\n ajv.addKeyword(ADDITIONAL_PROPERTY_FLAG);\n ajv.addKeyword(RJSF_ADDITONAL_PROPERTIES_FLAG);\n\n // add more schemas to validate against\n if (Array.isArray(additionalMetaSchemas)) {\n ajv.addMetaSchema(additionalMetaSchemas);\n }\n\n // add more custom formats to validate against\n if (isObject(customFormats)) {\n Object.keys(customFormats).forEach((formatName) => {\n ajv.addFormat(formatName, customFormats[formatName]);\n });\n }\n\n return ajv;\n}\n","import Ajv, { ErrorObject, ValidateFunction } from 'ajv';\nimport get from 'lodash/get';\nimport {\n createErrorHandler,\n CustomValidator,\n ErrorSchema,\n ErrorTransformer,\n FormContextType,\n getDefaultFormState,\n getUiOptions,\n PROPERTIES_KEY,\n RJSFSchema,\n RJSFValidationError,\n ROOT_SCHEMA_PREFIX,\n StrictRJSFSchema,\n toErrorList,\n toErrorSchema,\n UiSchema,\n unwrapErrorHandler,\n ValidationData,\n validationDataMerge,\n ValidatorType,\n withIdRefPrefix,\n} from '@rjsf/utils';\n\nimport { CustomValidatorOptionsType, Localizer } from './types';\nimport createAjvInstance from './createAjvInstance';\n\n/** `ValidatorType` implementation that uses the AJV 8 validation mechanism.\n */\nexport default class AJV8Validator<T = any, S extends StrictRJSFSchema = RJSFSchema, F extends FormContextType = any>\n implements ValidatorType<T, S, F>\n{\n /** The AJV instance to use for all validations\n *\n * @private\n */\n private ajv: Ajv;\n\n /** The Localizer function to use for localizing Ajv errors\n *\n * @private\n */\n readonly localizer?: Localizer;\n\n /** Constructs an `AJV8Validator` instance using the `options`\n *\n * @param options - The `CustomValidatorOptionsType` options that are used to create the AJV instance\n * @param [localizer] - If provided, is used to localize a list of Ajv `ErrorObject`s\n */\n constructor(options: CustomValidatorOptionsType, localizer?: Localizer) {\n const { additionalMetaSchemas, customFormats, ajvOptionsOverrides, ajvFormatOptions, AjvClass } = options;\n this.ajv = createAjvInstance(additionalMetaSchemas, customFormats, ajvOptionsOverrides, ajvFormatOptions, AjvClass);\n this.localizer = localizer;\n }\n\n /** Converts an `errorSchema` into a list of `RJSFValidationErrors`\n *\n * @param errorSchema - The `ErrorSchema` instance to convert\n * @param [fieldPath=[]] - The current field path, defaults to [] if not specified\n * @deprecated - Use the `toErrorList()` function provided by `@rjsf/utils` instead. This function will be removed in\n * the next major release.\n */\n toErrorList(errorSchema?: ErrorSchema<T>, fieldPath: string[] = []) {\n return toErrorList(errorSchema, fieldPath);\n }\n\n /** Transforming the error output from ajv to format used by @rjsf/utils.\n * At some point, components should be updated to support ajv.\n *\n * @param errors - The list of AJV errors to convert to `RJSFValidationErrors`\n * @param [uiSchema] - An optional uiSchema that is passed to `transformErrors` and `customValidate`\n * @protected\n */\n protected transformRJSFValidationErrors(\n errors: ErrorObject[] = [],\n uiSchema?: UiSchema<T, S, F>\n ): RJSFValidationError[] {\n return errors.map((e: ErrorObject) => {\n const { instancePath, keyword, params, schemaPath, parentSchema, ...rest } = e;\n let { message = '' } = rest;\n let property = instancePath.replace(/\\//g, '.');\n let stack = `${property} ${message}`.trim();\n\n if ('missingProperty' in params) {\n property = property ? `${property}.${params.missingProperty}` : params.missingProperty;\n const currentProperty: string = params.missingProperty;\n const uiSchemaTitle = getUiOptions(get(uiSchema, `${property.replace(/^\\./, '')}`)).title;\n\n if (uiSchemaTitle) {\n message = message.replace(currentProperty, uiSchemaTitle);\n } else {\n const parentSchemaTitle = get(parentSchema, [PROPERTIES_KEY, currentProperty, 'title']);\n\n if (parentSchemaTitle) {\n message = message.replace(currentProperty, parentSchemaTitle);\n }\n }\n\n stack = message;\n } else {\n const uiSchemaTitle = getUiOptions<T, S, F>(get(uiSchema, `${property.replace(/^\\./, '')}`)).title;\n\n if (uiSchemaTitle) {\n stack = `'${uiSchemaTitle}' ${message}`.trim();\n } else {\n const parentSchemaTitle = parentSchema?.title;\n\n if (parentSchemaTitle) {\n stack = `'${parentSchemaTitle}' ${message}`.trim();\n }\n }\n }\n\n // put data in expected format\n return {\n name: keyword,\n property,\n message,\n params, // specific to ajv\n stack,\n schemaPath,\n };\n });\n }\n\n /** Runs the pure validation of the `schema` and `formData` without any of the RJSF functionality. Provided for use\n * by the playground. Returns the `errors` from the validation\n *\n * @param schema - The schema against which to validate the form data * @param schema\n * @param formData - The form data to validate\n */\n rawValidation<Result = any>(schema: RJSFSchema, formData?: T): { errors?: Result[]; validationError?: Error } {\n let compilationError: Error | undefined = undefined;\n let compiledValidator: ValidateFunction | undefined;\n if (schema['$id']) {\n compiledValidator = this.ajv.getSchema(schema['$id']);\n }\n try {\n if (compiledValidator === undefined) {\n compiledValidator = this.ajv.compile(schema);\n }\n compiledValidator(formData);\n } catch (err) {\n compilationError = err as Error;\n }\n\n let errors;\n if (compiledValidator) {\n if (typeof this.localizer === 'function') {\n this.localizer(compiledValidator.errors);\n }\n errors = compiledValidator.errors || undefined;\n\n // Clear errors to prevent persistent errors, see #1104\n compiledValidator.errors = null;\n }\n\n return {\n errors: errors as unknown as Result[],\n validationError: compilationError,\n };\n }\n\n /** This function processes the `formData` with an optional user contributed `customValidate` function, which receives\n * the form data and a `errorHandler` function that will be used to add custom validation errors for each field. Also\n * supports a `transformErrors` function that will take the raw AJV validation errors, prior to custom validation and\n * transform them in what ever way it chooses.\n *\n * @param formData - The form data to validate\n * @param schema - The schema against which to validate the form data\n * @param [customValidate] - An optional function that is used to perform custom validation\n * @param [transformErrors] - An optional function that is used to transform errors after AJV validation\n * @param [uiSchema] - An optional uiSchema that is passed to `transformErrors` and `customValidate`\n */\n validateFormData(\n formData: T | undefined,\n schema: S,\n customValidate?: CustomValidator<T, S, F>,\n transformErrors?: ErrorTransformer<T, S, F>,\n uiSchema?: UiSchema<T, S, F>\n ): ValidationData<T> {\n const rawErrors = this.rawValidation<ErrorObject>(schema, formData);\n const { validationError: invalidSchemaError } = rawErrors;\n let errors = this.transformRJSFValidationErrors(rawErrors.errors, uiSchema);\n\n if (invalidSchemaError) {\n errors = [...errors, { stack: invalidSchemaError!.message }];\n }\n if (typeof transformErrors === 'function') {\n errors = transformErrors(errors, uiSchema);\n }\n\n let errorSchema = toErrorSchema<T>(errors);\n\n if (invalidSchemaError) {\n errorSchema = {\n ...errorSchema,\n $schema: {\n __errors: [invalidSchemaError!.message],\n },\n };\n }\n\n if (typeof customValidate !== 'function') {\n return { errors, errorSchema };\n }\n\n // Include form data with undefined values, which is required for custom validation.\n const newFormData = getDefaultFormState<T, S, F>(this, schema, formData, schema, true) as T;\n\n const errorHandler = customValidate(newFormData, createErrorHandler<T>(newFormData), uiSchema);\n const userErrorSchema = unwrapErrorHandler<T>(errorHandler);\n return validationDataMerge<T>({ errors, errorSchema }, userErrorSchema);\n }\n\n /** Validates data against a schema, returning true if the data is valid, or\n * false otherwise. If the schema is invalid, then this function will return\n * false.\n *\n * @param schema - The schema against which to validate the form data\n * @param formData - The form data to validate\n * @param rootSchema - The root schema used to provide $ref resolutions\n */\n isValid(schema: S, formData: T | undefined, rootSchema: S) {\n const rootSchemaId = rootSchema['$id'] ?? ROOT_SCHEMA_PREFIX;\n try {\n // add the rootSchema ROOT_SCHEMA_PREFIX as id.\n // then rewrite the schema ref's to point to the rootSchema\n // this accounts for the case where schema have references to models\n // that lives in the rootSchema but not in the schema in question.\n if (this.ajv.getSchema(rootSchemaId) === undefined) {\n this.ajv.addSchema(rootSchema, rootSchemaId);\n }\n const schemaWithIdRefPrefix = withIdRefPrefix<S>(schema) as S;\n let compiledValidator: ValidateFunction | undefined;\n if (schemaWithIdRefPrefix['$id']) {\n compiledValidator = this.ajv.getSchema(schemaWithIdRefPrefix['$id']);\n }\n if (compiledValidator === undefined) {\n compiledValidator = this.ajv.compile(schemaWithIdRefPrefix);\n }\n const result = compiledValidator(formData);\n return result as boolean;\n } catch (e) {\n console.warn('Error encountered compiling schema:', e);\n return false;\n } finally {\n // TODO: A function should be called if the root schema changes so we don't have to remove and recompile the schema every run.\n // make sure we remove the rootSchema from the global ajv instance\n this.ajv.removeSchema(rootSchemaId);\n }\n }\n}\n","import { FormContextType, RJSFSchema, StrictRJSFSchema, ValidatorType } from '@rjsf/utils';\n\nimport { CustomValidatorOptionsType, Localizer } from './types';\nimport AJV8Validator from './validator';\n\n/** Creates and returns a customized implementation of the `ValidatorType` with the given customization `options` if\n * provided.\n *\n * @param [options={}] - The `CustomValidatorOptionsType` options that are used to create the `ValidatorType` instance\n * @param [localizer] - If provided, is used to localize a list of Ajv `ErrorObject`s\n */\nexport default function customizeValidator<\n T = any,\n S extends StrictRJSFSchema = RJSFSchema,\n F extends FormContextType = any\n>(options: CustomValidatorOptionsType = {}, localizer?: Localizer): ValidatorType<T, S, F> {\n return new AJV8Validator<T, S, F>(options, localizer);\n}\n","import customizeValidator from './customizeValidator';\n\nexport { customizeValidator };\nexport * from './types';\n\nexport default customizeValidator();\n"],"names":["AJV_CONFIG","allErrors","multipleOfPrecision","strict","verbose","COLOR_FORMAT_REGEX","DATA_URL_FORMAT_REGEX","AJV8Validator","options","localizer","this","ajv","additionalMetaSchemas","customFormats","ajvOptionsOverrides","ajvFormatOptions","AjvClass","Ajv","_extends","addFormats","addFormat","addKeyword","ADDITIONAL_PROPERTY_FLAG","RJSF_ADDITONAL_PROPERTIES_FLAG","Array","isArray","addMetaSchema","isObject","Object","keys","forEach","formatName","createAjvInstance","_proto","prototype","toErrorList","errorSchema","fieldPath","transformRJSFValidationErrors","errors","uiSchema","map","e","instancePath","keyword","params","schemaPath","parentSchema","_rest$message","_objectWithoutPropertiesLoose","_excluded","message","property","replace","stack","trim","currentProperty","missingProperty","uiSchemaTitle","getUiOptions","get","title","parentSchemaTitle","PROPERTIES_KEY","name","rawValidation","schema","formData","compiledValidator","compilationError","undefined","getSchema","compile","err","validationError","validateFormData","customValidate","transformErrors","rawErrors","invalidSchemaError","concat","toErrorSchema","$schema","__errors","newFormData","getDefaultFormState","errorHandler","createErrorHandler","userErrorSchema","unwrapErrorHandler","validationDataMerge","isValid","rootSchema","_rootSchema$$id","rootSchemaId","ROOT_SCHEMA_PREFIX","addSchema","schemaWithIdRefPrefix","withIdRefPrefix","console","warn","removeSchema","customizeValidator","index"],"mappings":"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"}
|