2016-12-04 18:07:02 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class EmailValidator < ActiveModel::EachValidator
|
|
|
|
def validate_each(record, attribute, value)
|
|
|
|
record.errors.add(attribute, I18n.t('users.invalid_email')) if blocked_email?(value)
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def blocked_email?(value)
|
2017-04-04 15:04:44 +00:00
|
|
|
on_blacklist?(value) || not_on_whitelist?(value)
|
|
|
|
end
|
|
|
|
|
|
|
|
def on_blacklist?(value)
|
|
|
|
return false if Rails.configuration.x.email_domains_blacklist.blank?
|
|
|
|
|
2016-12-04 18:07:02 +00:00
|
|
|
domains = Rails.configuration.x.email_domains_blacklist.gsub('.', '\.')
|
|
|
|
regexp = Regexp.new("@(.+\\.)?(#{domains})", true)
|
|
|
|
|
|
|
|
value =~ regexp
|
|
|
|
end
|
2017-04-04 15:04:44 +00:00
|
|
|
|
|
|
|
def not_on_whitelist?(value)
|
|
|
|
return false if Rails.configuration.x.email_domains_whitelist.blank?
|
|
|
|
|
|
|
|
domains = Rails.configuration.x.email_domains_whitelist.gsub('.', '\.')
|
|
|
|
regexp = Regexp.new("@(.+\\.)?(#{domains})", true)
|
|
|
|
|
|
|
|
value !~ regexp
|
|
|
|
end
|
2016-12-04 18:07:02 +00:00
|
|
|
end
|