2017-08-17 22:00:37 +05:30
|
|
|
class GroupMembersFinder
|
|
|
|
def initialize(group)
|
|
|
|
@group = group
|
|
|
|
end
|
|
|
|
|
|
|
|
def execute
|
|
|
|
group_members = @group.members
|
|
|
|
|
|
|
|
return group_members unless @group.parent
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
parents_members = GroupMember.non_request
|
|
|
|
.where(source_id: @group.ancestors.select(:id))
|
|
|
|
.where.not(user_id: @group.users.select(:id))
|
2017-08-17 22:00:37 +05:30
|
|
|
|
|
|
|
wheres = ["members.id IN (#{group_members.select(:id).to_sql})"]
|
|
|
|
wheres << "members.id IN (#{parents_members.select(:id).to_sql})"
|
|
|
|
|
|
|
|
GroupMember.where(wheres.join(' OR '))
|
|
|
|
end
|
|
|
|
end
|