2019-07-02 03:10:25 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module GroupInteractions
|
|
|
|
extend ActiveSupport::Concern
|
|
|
|
|
|
|
|
class_methods do
|
|
|
|
|
|
|
|
def member_map(target_group_ids, account_id)
|
|
|
|
follow_mapping(GroupAccount.where(group_id: target_group_ids, account_id: account_id), :group_id)
|
|
|
|
end
|
|
|
|
|
|
|
|
def admin_map(target_group_ids, account_id)
|
2019-07-20 02:04:08 +03:00
|
|
|
follow_mapping(GroupAccount.where(group_id: target_group_ids, account_id: account_id, role: :admin), :group_id)
|
|
|
|
end
|
|
|
|
|
2019-07-02 03:10:25 -04:00
|
|
|
private
|
|
|
|
|
|
|
|
def follow_mapping(query, field)
|
|
|
|
query.pluck(field).each_with_object({}) { |id, mapping| mapping[id] = true }
|
|
|
|
end
|
2019-07-20 02:04:08 +03:00
|
|
|
|
2019-07-02 03:10:25 -04:00
|
|
|
end
|
|
|
|
|
2019-08-09 15:11:11 +03:00
|
|
|
def accounts_for_local_distribution
|
|
|
|
accounts.local
|
|
|
|
.joins(:user)
|
|
|
|
.where('users.current_sign_in_at > ?', User::ACTIVE_DURATION.ago)
|
2019-08-20 03:10:22 +03:00
|
|
|
.where('users.id NOT IN (SELECT thing_id FROM settings WHERE thing_type = \'User\' AND var = \'group_in_home_feed\' AND value = \'--- false
|
|
|
|
\')')
|
2019-08-09 15:11:11 +03:00
|
|
|
end
|
|
|
|
|
2019-07-02 03:10:25 -04:00
|
|
|
end
|