gitlab-org--gitlab-foss/app/finders/users_finder.rb

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

159 lines
3.3 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
2017-05-15 13:53:12 +00:00
# UsersFinder
#
# Used to filter users by set of params
#
# Arguments:
# current_user - which user use
# params:
# username: string
# extern_uid: string
# provider: string
# search: string
# active: boolean
# blocked: boolean
# external: boolean
# non_external: boolean
# without_projects: boolean
# sort: string
# id: integer
# non_internal: boolean
2017-05-15 13:53:12 +00:00
#
class UsersFinder
include CreatedAtFilter
2017-09-28 16:49:42 +00:00
include CustomAttributesFilter
2017-07-07 09:38:01 +00:00
2017-05-15 13:53:12 +00:00
attr_accessor :current_user, :params
def initialize(current_user, params = {})
@current_user = current_user
@params = params
end
def execute
users = base_scope
2017-05-15 13:53:12 +00:00
users = by_username(users)
users = by_id(users)
users = by_admins(users)
2017-05-15 13:53:12 +00:00
users = by_search(users)
users = by_blocked(users)
users = by_active(users)
users = by_external_identity(users)
users = by_external(users)
users = by_non_external(users)
users = by_2fa(users)
users = by_created_at(users)
users = by_without_projects(users)
2017-09-28 16:49:42 +00:00
users = by_custom_attributes(users)
users = by_non_internal(users)
users = by_without_project_bots(users)
2017-05-15 13:53:12 +00:00
order(users)
2017-05-15 13:53:12 +00:00
end
private
def base_scope
scope = current_user&.admin? ? User.all : User.without_forbidden_states
scope.order_id_desc
end
2017-05-15 13:53:12 +00:00
def by_username(users)
return users unless params[:username]
users.by_username(params[:username])
2017-05-15 13:53:12 +00:00
end
def by_id(users)
return users unless params[:id]
users.id_in(params[:id])
end
def by_admins(users)
return users unless params[:admins] && current_user&.can_read_all_resources?
users.admins
end
2017-05-15 13:53:12 +00:00
def by_search(users)
return users unless params[:search].present?
users.search(params[:search], with_private_emails: current_user&.admin?)
2017-05-15 13:53:12 +00:00
end
def by_blocked(users)
return users unless params[:blocked]
users.blocked
end
def by_active(users)
return users unless params[:active]
users.active
end
# rubocop: disable CodeReuse/ActiveRecord
2017-05-15 13:53:12 +00:00
def by_external_identity(users)
return users unless current_user&.admin? && params[:extern_uid] && params[:provider]
2017-05-15 13:53:12 +00:00
users.joins(:identities).merge(Identity.with_extern_uid(params[:provider], params[:extern_uid]))
end
# rubocop: enable CodeReuse/ActiveRecord
2017-05-15 13:53:12 +00:00
# rubocop: disable CodeReuse/ActiveRecord
2017-05-15 13:53:12 +00:00
def by_external(users)
return users unless params[:external]
users.external
end
# rubocop: enable CodeReuse/ActiveRecord
def by_non_external(users)
return users unless params[:non_external]
users.non_external
end
def by_2fa(users)
case params[:two_factor]
when 'enabled'
users.with_two_factor
when 'disabled'
users.without_two_factor
else
users
end
end
def by_without_projects(users)
return users unless params[:without_projects]
users.without_projects
end
def by_non_internal(users)
return users unless params[:non_internal]
users.non_internal
end
def by_without_project_bots(users)
return users unless params[:without_project_bots]
users.without_project_bot
end
# rubocop: disable CodeReuse/ActiveRecord
def order(users)
return users unless params[:sort]
users.order_by(params[:sort])
end
# rubocop: enable CodeReuse/ActiveRecord
2017-05-15 13:53:12 +00:00
end
UsersFinder.prepend_mod_with('UsersFinder')