debian-mirror-gitlab/app/finders/groups/accepting_group_transfers_finder.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

65 lines
1.6 KiB
Ruby
Raw Permalink Normal View History

2022-10-11 01:57:18 +05:30
# frozen_string_literal: true
module Groups
class AcceptingGroupTransfersFinder < Base
include Gitlab::Utils::StrongMemoize
def initialize(current_user, group_to_be_transferred, params = {})
@current_user = current_user
@group_to_be_transferred = group_to_be_transferred
@params = params
end
def execute
return Group.none unless can_transfer_group?
2022-11-25 23:54:43 +05:30
items = find_all_groups
2022-10-11 01:57:18 +05:30
items = by_search(items)
sort(items)
end
private
attr_reader :current_user, :group_to_be_transferred, :params
def find_groups
GroupsFinder.new( # rubocop: disable CodeReuse/Finder
current_user,
min_access_level: Gitlab::Access::OWNER,
exclude_group_ids: exclude_groups
).execute.without_order
end
def find_all_groups
::Namespace.from_union(
[
find_groups,
groups_originating_from_group_shares_with_owner_access
]
)
end
def groups_originating_from_group_shares_with_owner_access
GroupGroupLink
.with_owner_access
.groups_accessible_via(
current_user.owned_groups.select(:id)
).id_not_in(exclude_groups)
end
def exclude_groups
strong_memoize(:exclude_groups) do
exclude_groups = group_to_be_transferred.self_and_descendants.pluck_primary_key
exclude_groups << group_to_be_transferred.parent_id if group_to_be_transferred.parent_id
exclude_groups
end
end
def can_transfer_group?
Ability.allowed?(current_user, :admin_group, group_to_be_transferred)
end
end
end