debian-mirror-gitlab/app/finders/groups_finder.rb

158 lines
4.1 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2018-03-17 18:26:18 +05:30
# GroupsFinder
#
# Used to filter Groups by a set of params
#
# Arguments:
# current_user - which user is requesting groups
# params:
# owned: boolean
# parent: Group
# all_available: boolean (defaults to true)
2018-11-18 11:00:15 +05:30
# min_access_level: integer
2021-10-27 15:23:28 +05:30
# search: string
2019-07-07 11:18:12 +05:30
# exclude_group_ids: array of integers
2021-01-03 14:25:43 +05:30
# include_parent_descendants: boolean (defaults to false) - includes descendant groups when
# filtering by parent. The parent param must be present.
2022-10-11 01:57:18 +05:30
# include_ancestors: boolean (defaults to true)
2018-03-17 18:26:18 +05:30
#
# Users with full private access can see all groups. The `owned` and `parent`
# params can be used to restrict the groups that are returned.
#
# Anonymous users will never return any `owned` groups. They will return all
# public groups instead, even if `all_available` is set to false.
2016-06-02 11:05:42 +05:30
class GroupsFinder < UnionFinder
2018-03-17 18:26:18 +05:30
include CustomAttributesFilter
2017-08-17 22:00:37 +05:30
def initialize(current_user = nil, params = {})
@current_user = current_user
@params = params
end
2016-06-02 11:05:42 +05:30
2017-08-17 22:00:37 +05:30
def execute
2017-09-10 17:25:29 +05:30
items = all_groups.map do |item|
2018-03-17 18:26:18 +05:30
item = by_parent(item)
item = by_custom_attributes(item)
2019-07-07 11:18:12 +05:30
item = exclude_group_ids(item)
2021-10-27 15:23:28 +05:30
item = by_search(item)
2018-03-17 18:26:18 +05:30
item
2017-09-10 17:25:29 +05:30
end
2018-03-17 18:26:18 +05:30
2017-09-10 17:25:29 +05:30
find_union(items, Group).with_route.order_id_desc
2016-06-02 11:05:42 +05:30
end
private
2017-08-17 22:00:37 +05:30
attr_reader :current_user, :params
def all_groups
2018-03-17 18:26:18 +05:30
return [owned_groups] if params[:owned]
2018-11-18 11:00:15 +05:30
return [groups_with_min_access_level] if min_access_level?
2020-01-01 13:55:28 +05:30
return [Group.all] if current_user&.can_read_all_resources? && all_available?
2016-06-02 11:05:42 +05:30
2018-03-17 18:26:18 +05:30
groups = []
2022-10-11 01:57:18 +05:30
groups = get_groups_for_user if current_user
2022-01-26 12:08:38 +05:30
2018-03-17 18:26:18 +05:30
groups << Group.unscoped.public_to_user(current_user) if include_public_groups?
groups << Group.none if groups.empty?
2016-06-02 11:05:42 +05:30
groups
end
2017-08-17 22:00:37 +05:30
2017-09-10 17:25:29 +05:30
def groups_for_ancestors
current_user.authorized_groups
end
def groups_for_descendants
current_user.groups
end
2018-12-05 23:21:45 +05:30
# rubocop: disable CodeReuse/ActiveRecord
2018-11-18 11:00:15 +05:30
def groups_with_min_access_level
groups = current_user
.groups
.where('members.access_level >= ?', params[:min_access_level])
2022-07-16 23:28:13 +05:30
if Feature.enabled?(:use_traversal_ids_groups_finder, current_user)
2022-01-26 12:08:38 +05:30
groups.self_and_descendants
else
Gitlab::ObjectHierarchy
.new(groups)
.base_and_descendants
end
2018-11-18 11:00:15 +05:30
end
2018-12-05 23:21:45 +05:30
# rubocop: enable CodeReuse/ActiveRecord
2018-11-18 11:00:15 +05:30
2019-07-07 11:18:12 +05:30
def exclude_group_ids(groups)
return groups unless params[:exclude_group_ids]
groups.id_not_in(params[:exclude_group_ids])
end
2018-12-05 23:21:45 +05:30
# rubocop: disable CodeReuse/ActiveRecord
2017-08-17 22:00:37 +05:30
def by_parent(groups)
return groups unless params[:parent]
2021-01-03 14:25:43 +05:30
if include_parent_descendants?
groups.id_in(params[:parent].descendants)
else
groups.where(parent: params[:parent])
end
2017-08-17 22:00:37 +05:30
end
2018-12-05 23:21:45 +05:30
# rubocop: enable CodeReuse/ActiveRecord
2018-03-17 18:26:18 +05:30
2021-10-27 15:23:28 +05:30
# rubocop: disable CodeReuse/ActiveRecord
def by_search(groups)
return groups unless params[:search].present?
groups.search(params[:search], include_parents: params[:parent].blank?)
end
# rubocop: enable CodeReuse/ActiveRecord
2018-03-17 18:26:18 +05:30
def owned_groups
current_user&.owned_groups || Group.none
end
def include_public_groups?
2018-10-15 14:42:47 +05:30
current_user.nil? || all_available?
end
def all_available?
params.fetch(:all_available, true)
2018-03-17 18:26:18 +05:30
end
2018-11-18 11:00:15 +05:30
2021-01-03 14:25:43 +05:30
def include_parent_descendants?
params.fetch(:include_parent_descendants, false)
end
2018-11-18 11:00:15 +05:30
def min_access_level?
current_user && params[:min_access_level].present?
end
2022-10-11 01:57:18 +05:30
def include_ancestors?
params.fetch(:include_ancestors, true)
end
def get_groups_for_user
groups = []
if Feature.enabled?(:use_traversal_ids_groups_finder, current_user)
groups << if include_ancestors?
current_user.authorized_groups.self_and_ancestors
else
current_user.authorized_groups
end
groups << current_user.groups.self_and_descendants
elsif include_ancestors?
groups << Gitlab::ObjectHierarchy.new(groups_for_ancestors, groups_for_descendants).all_objects
else
groups << current_user.authorized_groups
groups << Gitlab::ObjectHierarchy.new(groups_for_descendants).base_and_descendants
end
groups
end
2016-06-02 11:05:42 +05:30
end