mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 18:52:45 +08:00
55a1394342
Doing .pluck(:column).first is a very common pattern in Discourse and in most cases, a limit cause isn't being added. Instead of adding a limit clause to all these callsites, this commit adds two new methods to ActiveRecord::Relation: pluck_first, equivalent to limit(1).pluck(*columns).first and pluck_first! which, like other finder methods, raises an exception when no record is found
22 lines
530 B
Ruby
22 lines
530 B
Ruby
# frozen_string_literal: true
|
|
|
|
class MinUsernameLengthValidator
|
|
def initialize(opts = {})
|
|
@opts = opts
|
|
end
|
|
|
|
def valid_value?(value)
|
|
return false if value > SiteSetting.max_username_length
|
|
@username = User.where('length(username) < ?', value).pluck_first(:username)
|
|
@username.blank?
|
|
end
|
|
|
|
def error_message
|
|
if @username.blank?
|
|
I18n.t("site_settings.errors.min_username_length_range")
|
|
else
|
|
I18n.t("site_settings.errors.min_username_length_exists", username: @username)
|
|
end
|
|
end
|
|
end
|