Correct validators so that existing error messages would look correct (#3668)
This commit is contained in:
parent
1a065fb146
commit
cdff1da901
5 changed files with 23 additions and 22 deletions
|
@ -57,7 +57,8 @@ class Account < ApplicationRecord
|
||||||
validates :username, uniqueness: { scope: :domain, case_sensitive: true }, if: -> { !local? && username_changed? }
|
validates :username, uniqueness: { scope: :domain, case_sensitive: true }, if: -> { !local? && username_changed? }
|
||||||
|
|
||||||
# Local user validations
|
# Local user validations
|
||||||
validates :username, format: { with: /\A[a-z0-9_]+\z/i }, uniqueness: { scope: :domain, case_sensitive: false }, length: { maximum: 30 }, unreserved: true, if: -> { local? && username_changed? }
|
validates :username, format: { with: /\A[a-z0-9_]+\z/i }, uniqueness: { scope: :domain, case_sensitive: false }, length: { maximum: 30 }, if: -> { local? && username_changed? }
|
||||||
|
validates_with UnreservedUsernameValidator, if: -> { local? && username_changed? }
|
||||||
validates :display_name, length: { maximum: 30 }, if: -> { local? && display_name_changed? }
|
validates :display_name, length: { maximum: 30 }, if: -> { local? && display_name_changed? }
|
||||||
validates :note, length: { maximum: 160 }, if: -> { local? && note_changed? }
|
validates :note, length: { maximum: 160 }, if: -> { local? && note_changed? }
|
||||||
|
|
||||||
|
|
|
@ -47,7 +47,7 @@ class User < ApplicationRecord
|
||||||
accepts_nested_attributes_for :account
|
accepts_nested_attributes_for :account
|
||||||
|
|
||||||
validates :locale, inclusion: I18n.available_locales.map(&:to_s), if: :locale?
|
validates :locale, inclusion: I18n.available_locales.map(&:to_s), if: :locale?
|
||||||
validates :email, email: true, if: :email_changed?
|
validates_with BlacklistedEmailValidator, if: :email_changed?
|
||||||
|
|
||||||
scope :recent, -> { order(id: :desc) }
|
scope :recent, -> { order(id: :desc) }
|
||||||
scope :admins, -> { where(admin: true) }
|
scope :admins, -> { where(admin: true) }
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
class EmailValidator < ActiveModel::EachValidator
|
class BlacklistedEmailValidator < ActiveModel::Validator
|
||||||
def validate_each(record, attribute, value)
|
def validate(user)
|
||||||
record.errors.add(attribute, I18n.t('users.invalid_email')) if blocked_email?(value)
|
user.errors.add(:email, I18n.t('users.invalid_email')) if blocked_email?(user.email)
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
@ -15,7 +15,7 @@ class EmailValidator < ActiveModel::EachValidator
|
||||||
return false if Rails.configuration.x.email_domains_blacklist.blank?
|
return false if Rails.configuration.x.email_domains_blacklist.blank?
|
||||||
|
|
||||||
domains = Rails.configuration.x.email_domains_blacklist.gsub('.', '\.')
|
domains = Rails.configuration.x.email_domains_blacklist.gsub('.', '\.')
|
||||||
regexp = Regexp.new("@(.+\\.)?(#{domains})", true)
|
regexp = Regexp.new("@(.+\\.)?(#{domains})", true)
|
||||||
|
|
||||||
value =~ regexp
|
value =~ regexp
|
||||||
end
|
end
|
||||||
|
@ -24,7 +24,7 @@ class EmailValidator < ActiveModel::EachValidator
|
||||||
return false if Rails.configuration.x.email_domains_whitelist.blank?
|
return false if Rails.configuration.x.email_domains_whitelist.blank?
|
||||||
|
|
||||||
domains = Rails.configuration.x.email_domains_whitelist.gsub('.', '\.')
|
domains = Rails.configuration.x.email_domains_whitelist.gsub('.', '\.')
|
||||||
regexp = Regexp.new("@(.+\\.)?(#{domains})$", true)
|
regexp = Regexp.new("@(.+\\.)?(#{domains})$", true)
|
||||||
|
|
||||||
value !~ regexp
|
value !~ regexp
|
||||||
end
|
end
|
15
app/validators/unreserved_username_validator.rb
Normal file
15
app/validators/unreserved_username_validator.rb
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
class UnreservedUsernameValidator < ActiveModel::Validator
|
||||||
|
def validate(account)
|
||||||
|
return if account.username.nil?
|
||||||
|
account.errors.add(:username, I18n.t('accounts.reserved_username')) if reserved_username?(account.username)
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def reserved_username?(value)
|
||||||
|
return false unless Setting.reserved_usernames
|
||||||
|
Setting.reserved_usernames.include?(value.downcase)
|
||||||
|
end
|
||||||
|
end
|
|
@ -1,15 +0,0 @@
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
class UnreservedValidator < ActiveModel::EachValidator
|
|
||||||
def validate_each(record, attribute, value)
|
|
||||||
return if value.nil?
|
|
||||||
record.errors.add(attribute, I18n.t('accounts.reserved_username')) if reserved_username?(value)
|
|
||||||
end
|
|
||||||
|
|
||||||
private
|
|
||||||
|
|
||||||
def reserved_username?(value)
|
|
||||||
return false unless Setting.reserved_usernames
|
|
||||||
Setting.reserved_usernames.include?(value.downcase)
|
|
||||||
end
|
|
||||||
end
|
|
Loading…
Reference in a new issue