BigW Consortium Gitlab

groups_controller.rb 2.1 KB
Newer Older
1
class Admin::GroupsController < Admin::ApplicationController
2
  before_action :group, only: [:edit, :update, :destroy, :project_update, :members_update]
3 4

  def index
5
    @groups = Group.with_statistics.with_route
6
    @groups = @groups.sort(@sort = params[:sort])
7
    @groups = @groups.search(params[:name]) if params[:name].present?
8
    @groups = @groups.page(params[:page])
9 10 11
  end

  def show
12
    @group = Group.with_statistics.joins(:route).group('routes.path').find_by_full_path(params[:id])
13
    @members = @group.members.order("access_level DESC").page(params[:members_page])
14
    @requesters = AccessRequestsFinder.new(@group).execute(current_user)
15
    @projects = @group.projects.with_statistics.page(params[:projects_page])
16 17 18 19 20 21 22 23 24 25
  end

  def new
    @group = Group.new
  end

  def edit
  end

  def create
26
    @group = Group.new(group_params)
27
    @group.name = @group.path.dup unless @group.name
28 29

    if @group.save
30
      @group.add_owner(current_user)
31
      redirect_to [:admin, @group], notice: "Group '#{@group.name}' was successfully created."
32
    else
33
      render "new"
34 35 36 37
    end
  end

  def update
38
    if @group.update_attributes(group_params)
39 40
      redirect_to [:admin, @group], notice: 'Group was successfully updated.'
    else
41
      render "edit"
42 43 44
    end
  end

45
  def members_update
46
    status = Members::CreateService.new(@group, current_user, params).execute
47

48 49 50 51 52
    if status
      redirect_to [:admin, @group], notice: 'Users were successfully added.'
    else
      redirect_to [:admin, @group], alert: 'No users specified.'
    end
53 54
  end

55
  def destroy
56
    Groups::DestroyService.new(@group, current_user).async_execute
57

58
    redirect_to admin_groups_path, alert: "Group '#{@group.name}' was scheduled for deletion."
59 60 61 62 63
  end

  private

  def group
64
    @group ||= Group.find_by_full_path(params[:id])
65
  end
66 67

  def group_params
68 69 70 71 72
    params.require(:group).permit(group_params_ce)
  end

  def group_params_ce
    [
73
      :avatar,
74
      :description,
75 76
      :lfs_enabled,
      :name,
77 78
      :path,
      :request_access_enabled,
79 80 81
      :visibility_level,
      :require_two_factor_authentication,
      :two_factor_grace_period
82
    ]
83
  end
84
end