FIX: A memoization bug in UserLookup and refactor (#13692)

`@group_lookup` memoization bug was introduced in #13587.
This commit is contained in:
Jarek Radosz 2021-07-14 13:51:33 +02:00 committed by GitHub
parent 2a95f892af
commit c750bfb4af
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 20 additions and 37 deletions

View File

@ -1,6 +1,13 @@
# frozen_string_literal: true # frozen_string_literal: true
class UserLookup class UserLookup
def self.lookup_columns
@user_lookup_columns ||= %i{id username name uploaded_avatar_id primary_group_id flair_group_id admin moderator trust_level}
end
def self.group_lookup_columns
@group_lookup_columns ||= %i{id name flair_icon flair_upload_id flair_bg_color flair_color}
end
def initialize(user_ids = []) def initialize(user_ids = [])
@user_ids = user_ids.tap(&:compact!).tap(&:uniq!).tap(&:flatten!) @user_ids = user_ids.tap(&:compact!).tap(&:uniq!).tap(&:flatten!)
@ -12,66 +19,42 @@ class UserLookup
end end
def primary_groups def primary_groups
@primary_groups ||= begin @primary_groups ||= users.values.each_with_object({}) do |user, hash|
hash = {} if user.primary_group_id
users.values.each do |u| hash[user.id] = groups[user.primary_group_id]
if u.primary_group_id
hash[u.id] = groups[u.primary_group_id]
end end
end end
hash
end
end end
def flair_groups def flair_groups
@flair_groups ||= begin @flair_groups ||= users.values.each_with_object({}) do |user, hash|
hash = {} if user.flair_group_id
users.values.each do |u| hash[user.id] = groups[user.flair_group_id]
if u.flair_group_id
hash[u.id] = groups[u.flair_group_id]
end end
end end
hash
end
end end
private private
def self.lookup_columns
@user_lookup_columns ||= %i{id username name uploaded_avatar_id primary_group_id flair_group_id admin moderator trust_level}
end
def self.group_lookup_columns
@group_lookup_columns ||= %i{id name flair_icon flair_upload_id flair_bg_color flair_color}
end
def users def users
@users ||= user_lookup_hash @users ||= User
end .where(id: @user_ids)
def user_lookup_hash
hash = {}
User.where(id: @user_ids)
.select(self.class.lookup_columns) .select(self.class.lookup_columns)
.each { |user| hash[user.id] = user } .index_by(&:id)
hash
end end
def groups def groups
@group_lookup = begin @group_lookup ||= begin
group_ids = users.values.map { |u| [u.primary_group_id, u.flair_group_id] } group_ids = users.values.map { |u| [u.primary_group_id, u.flair_group_id] }
group_ids.flatten! group_ids.flatten!
group_ids.uniq! group_ids.uniq!
group_ids.compact! group_ids.compact!
hash = {} Group
.includes(:flair_upload)
Group.includes(:flair_upload)
.where(id: group_ids) .where(id: group_ids)
.select(self.class.group_lookup_columns) .select(self.class.group_lookup_columns)
.each { |g| hash[g.id] = g } .index_by(&:id)
hash
end end
end end
end end