"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.parseIntersectionDef = void 0; const parseDef_1 = require("../parseDef.js"); const isJsonSchema7AllOfType = (type) => { if ('type' in type && type.type === 'string') return false; return 'allOf' in type; }; function parseIntersectionDef(def, refs) { const allOf = [ (0, parseDef_1.parseDef)(def.left._def, { ...refs, currentPath: [...refs.currentPath, 'allOf', '0'], }), (0, parseDef_1.parseDef)(def.right._def, { ...refs, currentPath: [...refs.currentPath, 'allOf', '1'], }), ].filter((x) => !!x); let unevaluatedProperties = refs.target === 'jsonSchema2019-09' ? { unevaluatedProperties: false } : undefined; const mergedAllOf = []; // If either of the schemas is an allOf, merge them into a single allOf allOf.forEach((schema) => { if (isJsonSchema7AllOfType(schema)) { mergedAllOf.push(...schema.allOf); if (schema.unevaluatedProperties === undefined) { // If one of the schemas has no unevaluatedProperties set, // the merged schema should also have no unevaluatedProperties set unevaluatedProperties = undefined; } } else { let nestedSchema = schema; if ('additionalProperties' in schema && schema.additionalProperties === false) { const { additionalProperties, ...rest } = schema; nestedSchema = rest; } else { // As soon as one of the schemas has additionalProperties set not to false, we allow unevaluatedProperties unevaluatedProperties = undefined; } mergedAllOf.push(nestedSchema); } }); return mergedAllOf.length ? { allOf: mergedAllOf, ...unevaluatedProperties, } : undefined; } exports.parseIntersectionDef = parseIntersectionDef; //# sourceMappingURL=intersection.js.map