FIX: Validate each value in an array custom field separately (#24659)

This commit is contained in:
Daniel Waterworth 2023-12-07 14:24:04 -06:00 committed by GitHub
parent bf48e14687
commit 611acaa6bc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 18 additions and 7 deletions

View File

@ -17,6 +17,10 @@ module HasCustomFields
end
end
def array_type?
Array === type
end
def validate(obj, name, value)
return if value.nil?
@ -29,7 +33,7 @@ module HasCustomFields
end
def serialize(value)
if value.is_a?(Hash) || type == :json || (Array === type && type[0] == :json)
if value.is_a?(Hash) || type == :json || (array_type? && type[0] == :json)
value.to_json
elsif TrueClass === value
"t"
@ -45,7 +49,7 @@ module HasCustomFields
array = nil
if Array === type
if array_type?
type = type[0]
array = true if return_array
end
@ -110,14 +114,15 @@ module HasCustomFields
def register_custom_field_type(name, type, max_length: nil)
max_length ||= DEFAULT_FIELD_DESCRIPTOR.max_length
if Array === type
descriptor = FieldDescriptor.new(type, max_length)
custom_field_meta_data[name] = descriptor
if descriptor.array_type?
Discourse.deprecate(
"Array types for custom fields are deprecated, use type :json instead",
drop_from: "3.3.0",
)
end
custom_field_meta_data[name] = FieldDescriptor.new(type, max_length)
end
def get_custom_field_descriptor(name)
@ -273,7 +278,7 @@ module HasCustomFields
descriptor = self.class.get_custom_field_descriptor(key)
field_type = descriptor.type
if Array === field_type || (field_type != :json && Array === value)
if descriptor.array_type? || (field_type != :json && Array === value)
value = Array(value || [])
value.compact!
sub_type = field_type[0]
@ -344,7 +349,13 @@ module HasCustomFields
def custom_fields_value_length
custom_fields.each do |name, value|
self.class.get_custom_field_descriptor(name).validate(self, name, value)
descriptor = self.class.get_custom_field_descriptor(name)
if descriptor.array_type?
Array(value).each { |v| descriptor.validate(self, name, v) }
else
descriptor.validate(self, name, value)
end
end
end
end