gitlab-org--gitlab-foss/app/controllers/admin/groups_controller.rb

120 lines
3.2 KiB
Ruby

# frozen_string_literal: true
class Admin::GroupsController < Admin::ApplicationController
include MembersPresentation
before_action :group, only: [:edit, :update, :destroy, :project_update, :members_update]
feature_category :subgroups
def index
@groups = groups.sort_by_attribute(@sort = params[:sort])
@groups = @groups.search(params[:name]) if params[:name].present?
@groups = @groups.page(params[:page])
end
# rubocop: disable CodeReuse/ActiveRecord
def show
# Group.with_statistics doesn't behave nicely when including other relations.
# Group.find_by_full_path includes the routes relation to avoid a common N+1
# (at the expense of this action: there are two queries here to find and retrieve
# the Group with statistics).
@group = Group.with_statistics.find(group&.id)
@members = present_members(
group_members.order("access_level DESC").page(params[:members_page]))
@requesters = present_members(
AccessRequestsFinder.new(@group).execute(current_user))
@projects = @group.projects.with_statistics.page(params[:projects_page])
end
# rubocop: enable CodeReuse/ActiveRecord
def new
@group = Group.new
@group.build_admin_note
end
def edit
@group.build_admin_note unless @group.admin_note
end
def create
@group = Group.new(group_params)
@group.name = @group.path.dup unless @group.name
if @group.save
@group.add_owner(current_user)
@group.create_namespace_settings
redirect_to [:admin, @group], notice: _('Group %{group_name} was successfully created.') % { group_name: @group.name }
else
render "new"
end
end
def update
@group.build_admin_note unless @group.admin_note
if @group.update(group_params)
redirect_to [:admin, @group], notice: _('Group was successfully updated.')
else
render "edit"
end
end
def members_update
member_params = params.permit(:user_ids, :access_level, :expires_at)
result = Members::CreateService.new(current_user, member_params.merge(limit: -1)).execute(@group)
if result[:status] == :success
redirect_to [:admin, @group], notice: _('Users were successfully added.')
else
redirect_to [:admin, @group], alert: result[:message]
end
end
def destroy
Groups::DestroyService.new(@group, current_user).async_execute
redirect_to admin_groups_path,
status: :found,
alert: _('Group %{group_name} was scheduled for deletion.') % { group_name: @group.name }
end
private
def groups
Group.with_statistics.with_route
end
def group
@group ||= Group.find_by_full_path(params[:id])
end
def group_members
@group.members
end
def group_params
params.require(:group).permit(allowed_group_params)
end
def allowed_group_params
[
:avatar,
:description,
:lfs_enabled,
:name,
:path,
:request_access_enabled,
:visibility_level,
:require_two_factor_authentication,
:two_factor_grace_period,
:project_creation_level,
:subgroup_creation_level,
admin_note_attributes: [
:note
]
]
end
end
Admin::GroupsController.prepend_if_ee('EE::Admin::GroupsController')