mirror of
https://github.com/discourse/discourse.git
synced 2025-01-19 07:02:46 +08:00
71be74ffd3
The recalculate code was never firing cause TrustLevel.calculate unconditionally returned a trust level. (albeit a wrong one) New code ensures we only bypass promotion checks for cases where trust level is locked. see: https://meta.discourse.org/t/user-trust-level-resets-to-zero-when-unlocked/255444
55 lines
1.3 KiB
Ruby
55 lines
1.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class InvalidTrustLevel < StandardError
|
|
end
|
|
|
|
class TrustLevel
|
|
def self.[](level)
|
|
raise InvalidTrustLevel if !valid?(level)
|
|
|
|
level
|
|
end
|
|
|
|
def self.levels
|
|
@levels ||= Enum.new(:newuser, :basic, :member, :regular, :leader, start: 0)
|
|
end
|
|
|
|
def self.valid?(level)
|
|
valid_range === level
|
|
end
|
|
|
|
def self.valid_range
|
|
(0..4)
|
|
end
|
|
|
|
def self.compare(current_level, level)
|
|
(current_level || 0) >= level
|
|
end
|
|
|
|
def self.name(level)
|
|
I18n.t("js.trust_levels.names.#{levels[level]}")
|
|
end
|
|
|
|
def self.calculate(user, use_previous_trust_level: false)
|
|
# First, use the manual locked level
|
|
return user.manual_locked_trust_level if user.manual_locked_trust_level.present?
|
|
|
|
# Then consider the group locked level (or the previous trust level)
|
|
granted_trust_level = user.group_granted_trust_level || 0
|
|
previous_trust_level = use_previous_trust_level ? find_previous_trust_level(user) : 0
|
|
|
|
[granted_trust_level, previous_trust_level, SiteSetting.default_trust_level].max
|
|
end
|
|
|
|
private
|
|
|
|
def self.find_previous_trust_level(user)
|
|
UserHistory
|
|
.where(action: UserHistory.actions[:change_trust_level])
|
|
.where(target_user_id: user.id)
|
|
.order(created_at: :desc)
|
|
.pick(:new_value)
|
|
.to_i
|
|
end
|
|
end
|