Class: Admin::GroupsController

Inherits:
ApplicationController show all
Includes:
MembersPresentation
Defined in:
app/controllers/admin/groups_controller.rb

Constant Summary

Constants inherited from ApplicationController

ApplicationController::DEFAULT_GITLAB_CACHE_CONTROL

Constants included from Gitlab::Logging::CloudflareHelper

Gitlab::Logging::CloudflareHelper::CLOUDFLARE_CUSTOM_HEADERS

Constants included from Gitlab::NoCacheHeaders

Gitlab::NoCacheHeaders::DEFAULT_GITLAB_NO_CACHE_HEADERS

Instance Method Summary collapse

Methods included from MembersPresentation

#preload_associations, #present_members

Methods included from EnforcesAdminAuthentication

#authenticate_admin!, #storable_location?

Methods inherited from ApplicationController

#not_found, #redirect_back_or_default, #render, #route_not_found

Methods included from Gitlab::Utils::StrongMemoize

#clear_memoization, #strong_memoize, #strong_memoized?

Methods included from Gitlab::Logging::CloudflareHelper

#store_cloudflare_headers!, #valid_cloudflare_header?

Methods included from Impersonation

#current_user

Methods included from InitializesCurrentUserMode

#current_user_mode

Methods included from Gitlab::Experimentation::ControllerConcern

#experiment_enabled?, #experiment_tracking_category_and_group, #frontend_experimentation_tracking_data, #record_experiment_user, #set_experimentation_subject_id_cookie, #track_experiment_event

Methods included from SessionsHelper

#limit_session_time, #unconfirmed_email?

Methods included from SessionlessAuthentication

#authenticate_sessionless_user!, #sessionless_bypass_admin_mode!, #sessionless_sign_in, #sessionless_user?

Methods included from Gitlab::SearchContext::ControllerConcern

#search_context

Methods included from EnforcesTwoFactorAuthentication

#check_two_factor_requirement, #current_user_requires_two_factor?, #skip_two_factor?, #two_factor_authentication_reason, #two_factor_authentication_required?, #two_factor_grace_period, #two_factor_grace_period_expired?, #two_factor_skippable?, #two_factor_verifier

Methods included from WorkhorseHelper

#send_artifacts_entry, #send_git_archive, #send_git_blob, #send_git_diff, #send_git_patch, #set_workhorse_internal_api_content_type, #workhorse_set_content_type!

Methods included from SafeParamsHelper

#safe_params

Methods included from PageLayoutHelper

#blank_container, #container_class, #favicon, #fluid_layout, #header_title, #nav, #page_card_attributes, #page_card_meta_tags, #page_description, #page_image, #page_title, #search_context, #sidebar

Methods included from GitlabRoutingHelper

#approve_access_request_group_member_path, #approve_access_request_project_member_path, #artifacts_action_path, #commit_url, #commits_url, #edit_milestone_path, #edit_pipeline_schedule_path, #environment_delete_path, #environment_metrics_path, #environment_path, #expose_fast_artifacts_path, #fast_browse_project_job_artifacts_path, #fast_download_project_job_artifacts_path, #fast_keep_project_job_artifacts_path, #gitlab_dashboard_snippets_path, #gitlab_raw_snippet_blob_path, #gitlab_raw_snippet_blob_url, #gitlab_raw_snippet_path, #gitlab_raw_snippet_url, #gitlab_snippet_note_path, #gitlab_snippet_note_url, #gitlab_snippet_notes_path, #gitlab_snippet_notes_url, #gitlab_snippet_path, #gitlab_snippet_url, #gitlab_toggle_award_emoji_snippet_note_path, #gitlab_toggle_award_emoji_snippet_note_url, #gitlab_toggle_award_emoji_snippet_path, #gitlab_toggle_award_emoji_snippet_url, #group_member_path, #group_members_url, #issue_path, #issue_url, #leave_group_members_path, #leave_project_members_path, #merge_request_path, #merge_request_url, #pipeline_job_url, #pipeline_path, #pipeline_schedule_path, #pipeline_schedules_path, #pipeline_url, #play_pipeline_schedule_path, #preview_markdown_path, #project_commits_path, #project_member_path, #project_members_url, #project_ref_path, #project_tree_path, #request_access_group_members_path, #request_access_project_members_path, #resend_invite_group_member_path, #resend_invite_project_member_path, #take_ownership_pipeline_schedule_path, #toggle_award_emoji_personal_snippet_path, #toggle_award_emoji_project_project_snippet_path, #toggle_award_emoji_project_project_snippet_url, #toggle_subscription_path, #wiki_page_path, #wiki_path

Methods included from API::Helpers::RelatedResourcesHelpers

#expose_path, #expose_url, #issues_available?, #mrs_available?

Methods included from Gitlab::NoCacheHeaders

#no_cache_headers

Methods included from Gitlab::GonHelper

#add_gon_variables, #default_avatar_url, #push_frontend_feature_flag

Methods included from WebpackHelper

#webpack_bundle_tag, #webpack_controller_bundle_tags, #webpack_entrypoint_paths, #webpack_public_host, #webpack_public_path

Methods included from StartupCssHelper

#use_startup_css?

Instance Method Details

#createObject


36
37
38
39
40
41
42
43
44
45
46
# File 'app/controllers/admin/groups_controller.rb', line 36

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 %{group_name} was successfully created.') % { group_name: @group.name }
  else
    render "new"
  end
end

#destroyObject


67
68
69
70
71
72
73
# File 'app/controllers/admin/groups_controller.rb', line 67

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

#editObject


33
34
# File 'app/controllers/admin/groups_controller.rb', line 33

def edit
end

#indexObject


8
9
10
11
12
# File 'app/controllers/admin/groups_controller.rb', line 8

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

#members_updateObject


56
57
58
59
60
61
62
63
64
65
# File 'app/controllers/admin/groups_controller.rb', line 56

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

#newObject

rubocop: enable CodeReuse/ActiveRecord


29
30
31
# File 'app/controllers/admin/groups_controller.rb', line 29

def new
  @group = Group.new
end

#showObject

rubocop: disable CodeReuse/ActiveRecord


15
16
17
18
19
20
21
22
23
24
25
26
# File 'app/controllers/admin/groups_controller.rb', line 15

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

#updateObject


48
49
50
51
52
53
54
# File 'app/controllers/admin/groups_controller.rb', line 48

def update
  if @group.update(group_params)
    redirect_to [:admin, @group], notice: _('Group was successfully updated.')
  else
    render "edit"
  end
end