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

64 lines
1.5 KiB
Ruby
Raw Normal View History

class Admin::GroupsController < Admin::ApplicationController
2012-12-25 22:52:20 +00:00
before_filter :group, only: [:edit, :show, :update, :destroy, :project_update, :project_teams_update]
def index
2012-12-10 03:14:05 +00:00
@groups = Group.order('name ASC')
@groups = @groups.search(params[:name]) if params[:name].present?
@groups = @groups.page(params[:page]).per(20)
end
def show
@members = @group.members.order("access_level DESC").page(params[:members_page]).per(30)
@projects = @group.projects.page(params[:projects_page]).per(30)
end
def new
@group = Group.new
end
def edit
end
def create
@group = Group.new(group_params)
@group.name = @group.path.dup unless @group.name
if @group.save
@group.add_owner(current_user)
redirect_to [:admin, @group], notice: 'Group was successfully created.'
else
render "new"
end
end
def update
if @group.update_attributes(group_params)
redirect_to [:admin, @group], notice: 'Group was successfully updated.'
else
render "edit"
end
end
2012-12-25 22:52:20 +00:00
def project_teams_update
@group.add_users(params[:user_ids].split(','), params[:access_level])
2013-04-10 02:43:02 +00:00
redirect_to [:admin, @group], notice: 'Users were successfully added.'
2012-12-25 22:52:20 +00:00
end
def destroy
@group.destroy
2012-10-22 18:21:34 +00:00
redirect_to admin_groups_path, notice: 'Group was successfully deleted.'
end
private
def group
2014-01-19 18:55:59 +00:00
@group = Group.find_by(path: params[:id])
end
def group_params
params.require(:group).permit(:name, :description, :path, :avatar)
end
end