83232be0e1
* add parent_id field to namespaces table to store relation with nested groups * create routes table to keep information about full path of every group and project * project/group lookup by full path from routes table Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
73 lines
1.8 KiB
Ruby
73 lines
1.8 KiB
Ruby
class Admin::GroupsController < Admin::ApplicationController
|
|
before_action :group, only: [:edit, :show, :update, :destroy, :project_update, :members_update]
|
|
|
|
def index
|
|
@groups = Group.all
|
|
@groups = @groups.sort(@sort = params[:sort])
|
|
@groups = @groups.search(params[:name]) if params[:name].present?
|
|
@groups = @groups.page(params[:page])
|
|
end
|
|
|
|
def show
|
|
@members = @group.members.order("access_level DESC").page(params[:members_page])
|
|
@requesters = AccessRequestsFinder.new(@group).execute(current_user)
|
|
@projects = @group.projects.page(params[:projects_page])
|
|
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
|
|
|
|
def members_update
|
|
@group.add_users(params[:user_ids].split(','), params[:access_level], current_user: current_user)
|
|
|
|
redirect_to [:admin, @group], notice: 'Users were successfully added.'
|
|
end
|
|
|
|
def destroy
|
|
DestroyGroupService.new(@group, current_user).async_execute
|
|
|
|
redirect_to admin_groups_path, alert: "Group '#{@group.name}' was scheduled for deletion."
|
|
end
|
|
|
|
private
|
|
|
|
def group
|
|
@group ||= Group.find_by_full_path(params[:id])
|
|
end
|
|
|
|
def group_params
|
|
params.require(:group).permit(
|
|
:avatar,
|
|
:description,
|
|
:lfs_enabled,
|
|
:name,
|
|
:path,
|
|
:request_access_enabled,
|
|
:visibility_level
|
|
)
|
|
end
|
|
end
|