Add validations to admin settings (#10348)
* Add validations to admin settings - Validate correct HTML markup - Validate presence of contact username & e-mail - Validate that all usernames are valid - Validate that enums have expected values * Fix code style issue * Fix testsmaster
parent
55a9658ad8
commit
555c4e11ba
@ -0,0 +1,20 @@ |
||||
# frozen_string_literal: true |
||||
|
||||
class ExistingUsernameValidator < ActiveModel::EachValidator |
||||
def validate_each(record, attribute, value) |
||||
return if value.blank? |
||||
|
||||
if options[:multiple] |
||||
missing_usernames = value.split(',').map { |username| username unless Account.find_local(username) }.compact |
||||
record.errors.add(attribute, I18n.t('existing_username_validator.not_found_multiple', usernames: missing_usernames.join(', '))) if missing_usernames.any? |
||||
else |
||||
record.errors.add(attribute, I18n.t('existing_username_validator.not_found')) unless Account.find_local(value) |
||||
end |
||||
end |
||||
|
||||
private |
||||
|
||||
def valid_html?(str) |
||||
Nokogiri::HTML.fragment(str).to_s == str |
||||
end |
||||
end |
@ -0,0 +1,14 @@ |
||||
# frozen_string_literal: true |
||||
|
||||
class HtmlValidator < ActiveModel::EachValidator |
||||
def validate_each(record, attribute, value) |
||||
return if value.blank? |
||||
record.errors.add(attribute, I18n.t('html_validator.invalid_markup')) unless valid_html?(value) |
||||
end |
||||
|
||||
private |
||||
|
||||
def valid_html?(str) |
||||
Nokogiri::HTML.fragment(str).to_s == str |
||||
end |
||||
end |
Loading…
Reference in new issue