Sha256: 7d57b9d499e86083b8ebfd289f275275cb7b6a6662bf33e27f27dccee9f1488a
Contents?: true
Size: 1.92 KB
Versions: 11
Compression:
Stored size: 1.92 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) properties = schema.properties || {} required_set = schema.required ? schema.required.to_set : Set.new remaining_keys = value.keys coerced_values = value.map do |name, v| s = 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
11 entries across 11 versions & 1 rubygems