Sha256: a563b25a4c6000907844506234925124057bfddcc9b494576c741478bdbf6e30
Contents?: true
Size: 1.94 KB
Versions: 6
Compression:
Stored size: 1.94 KB
Contents
class OpenAPIParser::SchemaValidator class ObjectValidator < Base # @param [Hash] value # @param [OpenAPIParser::Schemas::Schema] schema # @param [Boolean] parent_all_of true if component is nested under allOf # @param [String, nil] discriminator_property_name discriminator.property_name to ignore checking additional_properties def coerce_and_validate(value, schema, parent_all_of: false, discriminator_property_name: nil) return OpenAPIParser::ValidateError.build_error_result(value, schema) unless value.kind_of?(Hash) return [value, nil] unless schema.properties required_set = schema.required ? schema.required.to_set : Set.new remaining_keys = value.keys coerced_values = value.map do |name, v| s = schema.properties[name] coerced, err = if s remaining_keys.delete(name) validatable.validate_schema(v, s) else # TODO: we need to perform a validation based on schema.additional_properties here, if # additionalProperties are defined [v, nil] end return [nil, err] if err required_set.delete(name) [name, coerced] end remaining_keys.delete(discriminator_property_name) if discriminator_property_name if !remaining_keys.empty? && !parent_all_of && !schema.additional_properties # If object is nested in all of, the validation is already done in allOf validator. Or if # additionalProperties are defined, we will validate using that return [nil, OpenAPIParser::NotExistPropertyDefinition.new(remaining_keys, schema.object_reference)] end return [nil, OpenAPIParser::NotExistRequiredKey.new(required_set.to_a, schema.object_reference)] unless required_set.empty? value.merge!(coerced_values.to_h) if @coerce_value [value, nil] end end end
Version data entries
6 entries across 6 versions & 1 rubygems