Commit 5a5c094d authored by Alper Akgun's avatar Alper Akgun

Merge branch 'mmj-refactor-billing-code' into 'master'

Refactor code related to billing group members belonging to shared groups

See merge request gitlab-org/gitlab!81256
parents 7aa53b28 28a1fcfa
...@@ -582,10 +582,10 @@ module EE ...@@ -582,10 +582,10 @@ module EE
def billed_user_ids_excluding_guests def billed_user_ids_excluding_guests
strong_memoize(:billed_user_ids_excluding_guests) do strong_memoize(:billed_user_ids_excluding_guests) do
group_member_user_ids = billed_group_users(non_guests: true).distinct.pluck(:id) group_member_user_ids = billed_group_users(exclude_guests: true).distinct.pluck(:id)
project_member_user_ids = billed_project_users(non_guests: true).distinct.pluck(:id) project_member_user_ids = billed_project_users(exclude_guests: true).distinct.pluck(:id)
shared_group_user_ids = billed_shared_non_guests_group_users.distinct.pluck(:id) shared_group_user_ids = billed_shared_group_users(exclude_guests: true).distinct.pluck(:id)
shared_project_user_ids = billed_invited_non_guests_group_to_project_users.distinct.pluck(:id) shared_project_user_ids = billed_invited_group_to_project_users(exclude_guests: true).distinct.pluck(:id)
{ {
user_ids: (group_member_user_ids + project_member_user_ids + shared_group_user_ids + shared_project_user_ids).to_set, user_ids: (group_member_user_ids + project_member_user_ids + shared_group_user_ids + shared_project_user_ids).to_set,
...@@ -624,21 +624,21 @@ module EE ...@@ -624,21 +624,21 @@ module EE
end end
# Members belonging directly to Group or its subgroups # Members belonging directly to Group or its subgroups
def billed_group_users(non_guests: false) def billed_group_users(exclude_guests: false)
members = ::GroupMember.active_without_invites_and_requests.where( members = ::GroupMember.active_without_invites_and_requests.where(
source_id: self_and_descendants source_id: self_and_descendants
) )
members = members.non_guests if non_guests members = members.non_guests if exclude_guests
users_without_project_bots(members) users_without_project_bots(members)
end end
# Members belonging directly to Projects within Group or Projects within subgroups # Members belonging directly to Projects within Group or Projects within subgroups
def billed_project_users(non_guests: false) def billed_project_users(exclude_guests: false)
members = ::ProjectMember.without_invites_and_requests members = ::ProjectMember.without_invites_and_requests
members = members.non_guests if non_guests members = members.non_guests if exclude_guests
members = members.where( members = members.where(
source_id: ::Project.joins(:group).where(namespace: self_and_descendants) source_id: ::Project.joins(:group).where(namespace: self_and_descendants)
...@@ -648,13 +648,11 @@ module EE ...@@ -648,13 +648,11 @@ module EE
end end
# Members belonging to Groups invited to collaborate with Projects # Members belonging to Groups invited to collaborate with Projects
def billed_invited_group_to_project_users def billed_invited_group_to_project_users(exclude_guests: false)
members = invited_or_shared_group_members(invited_groups_in_projects) groups = (exclude_guests ? invited_group_as_non_guests_in_projects : invited_groups_in_projects)
users_without_project_bots(members) members = invited_or_shared_group_members(groups)
end members = members.non_guests if exclude_guests
def billed_invited_non_guests_group_to_project_users
members = invited_or_shared_group_members(invited_group_as_non_guests_in_projects).non_guests
users_without_project_bots(members) users_without_project_bots(members)
end end
...@@ -668,13 +666,11 @@ module EE ...@@ -668,13 +666,11 @@ module EE
end end
# Members belonging to Groups invited to collaborate with Groups and Subgroups # Members belonging to Groups invited to collaborate with Groups and Subgroups
def billed_shared_group_users def billed_shared_group_users(exclude_guests: false)
members = invited_or_shared_group_members(invited_group_in_groups) groups = (exclude_guests ? invited_non_guest_group_in_groups : invited_group_in_groups)
users_without_project_bots(members) members = invited_or_shared_group_members(groups)
end members = members.non_guests if exclude_guests
def billed_shared_non_guests_group_users
members = invited_or_shared_group_members(invited_non_guest_group_in_groups).non_guests
users_without_project_bots(members) users_without_project_bots(members)
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment