Class: Admin::ApplicationSettingsController
- Inherits:
-
ApplicationController
- Object
- ActionController::Base
- BaseActionController
- ApplicationController
- ApplicationController
- Admin::ApplicationSettingsController
- Defined in:
- app/controllers/admin/application_settings_controller.rb
Constant Summary collapse
- VALID_SETTING_PANELS =
%w[general repository ci_cd reporting metrics_and_profiling network preferences].freeze
- PARAM_JOB_ID_MAX_SIZE =
The current size of a sidekiq job’s jid is 24 characters. The size of the jid is an internal detail of Sidekiq, and they do not guarantee that it’ll stay the same. We chose 50 to give us room in case the size of the jid increases. The jid is alphanumeric, so 50 is very generous. There is a spec that ensures that the constant value is more than the size of an actual jid.
50
Constants included from CookiesHelper
CookiesHelper::COOKIE_TYPE_ENCRYPTED, CookiesHelper::COOKIE_TYPE_PERMANENT
Constants included from Gitlab::HttpRouter::RuleContext
Gitlab::HttpRouter::RuleContext::ALLOWED_ROUTER_RULE_ACTIONS, Gitlab::HttpRouter::RuleContext::ALLOWED_ROUTER_RULE_TYPES, Gitlab::HttpRouter::RuleContext::ROUTER_RULE_ACTIONS_WITHOUT_TYPE
Constants included from StrongPaginationParams
StrongPaginationParams::PAGINATION_PARAMS
Constants included from Gitlab::Logging::JsonMetadataHelper
Gitlab::Logging::JsonMetadataHelper::JSON_METADATA_HEADERS
Constants included from Gitlab::Logging::CloudflareHelper
Gitlab::Logging::CloudflareHelper::CLOUDFLARE_CUSTOM_HEADERS
Constants included from Gitlab::EndpointAttributes
Gitlab::EndpointAttributes::DEFAULT_URGENCY
Constants included from Impersonation
Impersonation::SESSION_KEYS_TO_DELETE
Constants included from PreferredLanguageSwitcherHelper
PreferredLanguageSwitcherHelper::SWITCHER_MINIMUM_TRANSLATION_LEVEL
Constants included from Routing::PseudonymizationHelper
Routing::PseudonymizationHelper::PSEUDONOMIZED_GROUP, Routing::PseudonymizationHelper::PSEUDONOMIZED_ID, Routing::PseudonymizationHelper::PSEUDONOMIZED_NAMESPACE, Routing::PseudonymizationHelper::PSEUDONOMIZED_PROJECT, Routing::PseudonymizationHelper::PSEUDONOMIZED_USERNAME
Constants included from Gitlab::NoCacheHeaders
Gitlab::NoCacheHeaders::DEFAULT_GITLAB_NO_CACHE_HEADERS
Instance Method Summary collapse
- #clear_repository_check_states ⇒ Object
- #integrations ⇒ Object
-
#lets_encrypt_terms_of_service ⇒ Object
Getting ToS url requires
directoryapi call to Let’s Encrypt which could result in 500 error/slow rendering on settings page Because of that we use separate controller action. - #reset_error_tracking_access_token ⇒ Object
- #reset_health_check_token ⇒ Object
- #reset_registration_token ⇒ Object
- #reset_vscode_extension_marketplace_extension_host_domain ⇒ Object
- #slack_app_manifest_download ⇒ Object
- #slack_app_manifest_share ⇒ Object
- #update ⇒ Object
- #usage_data ⇒ Object
Methods included from DefaultBranchProtection
#normalize_default_branch_params!
Methods included from IntegrationsHelper
#add_to_slack_link, #gitlab_slack_application_data, #instance_level_integrations?, #integration_event_description, #integration_event_field_name, #integration_event_title, #integration_form_data, #integration_issue_type, #integration_list_data, #integration_overrides_data, #integration_todo_target_type, #integration_webhook_event_human_name, #integrations_help_page_path, #jira_specific_form_data, #project_jira_issues_integration?, #scoped_edit_integration_path, #scoped_integration_path, #scoped_integrations_path, #scoped_overrides_integration_path, #scoped_reset_integration_path, #scoped_test_integration_path, #slack_integration_destroy_path, #slack_specific_form_data
Methods included from InternalRedirect
#full_path_for_uri, #host_allowed?, #referer_path, #safe_redirect_path, #safe_redirect_path_for_url, #sanitize_redirect
Methods included from EnforcesAdminAuthentication
#authenticate_admin!, #storable_location?
Methods inherited from ApplicationController
#feature_category, #handle_unverified_request, #not_found, #redirect_back_or_default, #render, #route_not_found, #urgency
Methods included from CookiesHelper
Methods included from Gitlab::HttpRouter::RuleMetrics
#increment_http_router_metrics
Methods included from StrongPaginationParams
Methods included from RequestPayloadLogger
Methods included from Gitlab::Logging::JsonMetadataHelper
Methods included from Gitlab::Logging::CloudflareHelper
#store_cloudflare_headers!, #valid_cloudflare_header?
Methods included from CheckRateLimit
Methods included from FlocOptOut
#floc_enabled?, #set_floc_opt_out_header
Methods included from Impersonation
Methods included from InitializesCurrentUserMode
Methods included from SessionsHelper
#fallback_to_email_otp_permitted?, #obfuscated_email, #passkey_authentication_data, #remember_me_enabled?, #render_email_otp_fallback_for_totp?, #session_expire_modal_data, #sign_in_form_app_data, #unconfirmed_email?, #verification_data, #webauthn_authentication_data
Methods included from VerifiesWithEmailHelper
#permitted_to_skip_email_otp_in_grace_period?, #treat_as_locked?, #trusted_ip_address?
Methods included from SessionlessAuthentication
#authenticate_sessionless_user!, #request_authenticator, #sessionless_bypass_admin_mode!, #sessionless_sign_in, #sessionless_user?
Methods included from PreferredLanguageSwitcherHelper
Methods included from Gitlab::SearchContext::ControllerConcern
Methods included from EnforcesTwoFactorAuthentication
#check_two_factor_requirement, #current_user_requires_two_factor?, #execute_action_for_2fa_reason, #mfa_help_page_url, #skip_two_factor?, #two_factor_authentication_required?, #two_factor_grace_period, #two_factor_grace_period_expired?, #two_factor_skippable?, #two_factor_verifier
Methods included from WorkhorseHelper
#attachment_content_disposition, #content_disposition_for_blob, #inline_content_disposition, #send_artifacts_entry, #send_dependency, #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
Methods included from PageLayoutHelper
#blank_container, #container_class, #favicon, #fluid_layout, #full_content_class, #header_title, #nav, #page_canonical_link, #page_card_attributes, #page_card_meta_tags, #page_description, #page_image, #page_itemtype, #page_title, #search_context, #sidebar, #user_status_properties
Methods included from Routing::PackagesHelper
Methods included from Routing::PseudonymizationHelper
#masked_page_url, #masked_query_params, #masked_referrer_url, #referrer_params
Methods included from Routing::GraphqlHelper
#graphql_etag_pipeline_path, #graphql_etag_pipeline_sha_path, #graphql_etag_project_on_demand_scan_counts_path
Methods included from Routing::WikiHelper
#group_wiki_page_url, #project_wiki_page_url, #wiki_page_path, #wiki_path
Methods included from Routing::SnippetsHelper
#gitlab_raw_snippet_blob_url, #gitlab_raw_snippet_url, #gitlab_snippet_note_path, #gitlab_snippet_notes_path, #gitlab_snippet_path, #gitlab_snippet_url, #gitlab_toggle_award_emoji_snippet_note_path, #preview_markdown_path, #toggle_award_emoji_personal_snippet_path, #toggle_award_emoji_project_project_snippet_path, #toggle_award_emoji_project_project_snippet_url
Methods included from Routing::PipelineSchedulesHelper
#edit_pipeline_schedule_path, #pipeline_schedule_path, #pipeline_schedules_path, #play_pipeline_schedule_path, #take_ownership_pipeline_schedule_path
Methods included from Routing::ArtifactsHelper
#artifacts_action_path, #expose_fast_artifacts_path, #fast_browse_project_job_artifacts_path, #fast_download_project_job_artifacts_path, #fast_keep_project_job_artifacts_path
Methods included from Routing::MembersHelper
Methods included from Routing::Groups::MembersHelper
#approve_access_request_group_member_path, #group_member_path, #group_members_url, #leave_group_members_path, #request_access_group_members_path, #resend_invite_group_member_path
Methods included from Routing::Projects::MembersHelper
#approve_access_request_project_member_path, #leave_project_members_path, #project_member_path, #project_members_url, #request_access_project_members_path, #resend_invite_project_member_path
Methods included from Routing::ProjectsHelper
#commit_url, #commits_url, #edit_milestone_path, #environment_delete_path, #environment_path, #issue_path, #issue_url, #merge_request_path, #merge_request_url, #pipeline_job_url, #pipeline_path, #pipeline_url, #project_commits_path, #project_ref_path, #project_tree_path, #release_url, #toggle_subscription_path, #work_item_url
Methods included from API::Helpers::RelatedResourcesHelpers
#expose_path, #expose_url, #issues_available?, #mrs_available?, #project_feature_string_access_level
Methods included from ApplicationSettingsHelper
#all_protocols_enabled?, #allowed_protocols_present?, #anti_spam_service_enabled?, #custom_admin_roles_available?, #default_search_scope_options_for_select, #deletion_protection_data, #deprecated_attributes, #enabled_protocol, #enabled_protocol_button, #expanded_by_default?, #external_authorization_allow_token_help_text, #external_authorization_client_certificate_help_text, #external_authorization_client_key_help_text, #external_authorization_client_pass_help_text, #external_authorization_client_url_help_text, #external_authorization_description, #external_authorization_service_attributes, #external_authorization_timeout_help_text, #external_authorization_url_help_text, #global_search_settings_checkboxes, #http_enabled?, #import_sources_checkboxes, #instance_clusters_enabled?, #integration_expanded?, #key_restriction_options_for_select, #kroki_available_formats, #oauth_providers_checkboxes, #pending_user_count, #registration_features_can_be_prompted?, #repository_storages_options_json, #restricted_level_checkboxes, #runner_token_expiration_interval_attributes, #sidekiq_job_limiter_mode_help_text, #sidekiq_job_limiter_modes_for_select, #signup_enabled?, #signup_form_data, #ssh_enabled?, #storage_weights, #user_oauth_applications?, #valid_runner_registrars, #visible_attributes, #vscode_extension_marketplace_settings_description, #vscode_extension_marketplace_settings_view
Methods included from ProjectsHelper
#able_to_see_forks_count?, #able_to_see_issues?, #able_to_see_merge_requests?, #any_projects?, #archiving_available?, #author_content_tag, #autodeploy_flash_notice, #badge_count, #branch_rules_path, #can_admin_associated_clusters?, #can_change_visibility_level?, #can_disable_emails?, #can_push_code?, #can_set_diff_preview_in_email?, #can_view_branch_rules?, #clusters_deprecation_alert_message, #dashboard_projects_app_data, #delete_confirm_phrase, #directory?, #error_tracking_setting_project_json, #explore_projects_tab?, #external_classification_label_help_message, #fork_button_data_attributes, #hidden_issue_icon, #home_panel_data_attributes, #http_clone_url_to_repo, #import_from_bitbucket_message, #inactive_project_deletion_date, #issue_css_classes, #issue_manual_ordering_class, #last_pipeline_from_status_cache, #last_push_event, #link_to_autodeploy_doc, #link_to_data_loss_doc, #link_to_member, #link_to_member_avatar, #link_to_namespace_change_doc, #link_to_project, #load_catalog_resources, #load_pipeline_status, #localized_project_human_access, #membership_locked?, #no_password_message, #notification_data_attributes, #project_archive_settings_app_data, #project_can_be_shared?, #project_classes, #project_coverage_chart_data_attributes, #project_incident_management_setting, #project_license_name, #project_pages_domain_choices, #project_permissions_panel_data, #project_unarchive_settings_app_data, #projects_filtered_search_and_sort_app_data, #push_project_breadcrumbs, #push_to_create_project_command, #remote_mirror_setting_enabled?, #remove_fork_project_confirm_json, #remove_fork_project_description_message, #remove_fork_project_warning_message, #remove_project_message, #show_archived_badge?, #show_auto_devops_implicitly_enabled_banner?, #show_clusters_alert?, #show_count?, #show_dashboard_projects_welcome_page?, #show_inactive_project_deletion_banner?, #show_invalid_gpg_key_message?, #show_lfs_misconfiguration_banner?, #show_mobile_devops_project_promo?, #show_no_password_message?, #show_no_ssh_key_message?, #show_terraform_banner?, #show_xcode_link?, #ssh_clone_url_to_repo, #star_count_data_attributes, #transfer_project_confirm_button, #transfer_project_message, #visibility_level_content, #visible_fork_source, #vue_fork_divergence_data, #xcode_uri_to_repo
Methods included from Gitlab::Allowable
Methods included from CompareHelper
#create_mr_button?, #create_mr_path, #project_compare_selector_data, #target_projects
Methods included from Gitlab::NoCacheHeaders
Methods included from Gitlab::GonHelper
#add_gon_feature_flags, #add_gon_user_specific, #add_gon_variables, #current_organization, #default_avatar_url, #push_application_setting, #push_force_frontend_feature_flag, #push_frontend_ability, #push_frontend_feature_flag, #push_namespace_setting, #push_to_gon_attributes
Methods included from Organizations::OrganizationHelper
#admin_organizations_index_app_data, #organization_activity_app_data, #organization_groups_and_projects_app_data, #organization_groups_edit_app_data, #organization_groups_new_app_data, #organization_index_app_data, #organization_layout_nav, #organization_new_app_data, #organization_projects_edit_app_data, #organization_settings_general_app_data, #organization_show_app_data, #organization_user_app_data, #ui_for_organizations_enabled?
Methods included from WebpackHelper
#prefetch_link_tag, #webpack_bundle_tag, #webpack_controller_bundle_tags, #webpack_entrypoint_paths, #webpack_preload_asset_tag, #webpack_public_host, #webpack_public_path
Methods included from ViteHelper
#universal_path_to_stylesheet, #universal_stylesheet_link_tag, #vite_enabled?, #vite_page_entrypoint_paths
Methods inherited from BaseActionController
#append_to_content_security_policy
Methods included from ContentSecurityPolicyPatch
#content_security_policy_with_context
Methods included from CurrentOrganization
Instance Method Details
#clear_repository_check_states ⇒ Object
115 116 117 118 119 120 121 122 |
# File 'app/controllers/admin/application_settings_controller.rb', line 115 def clear_repository_check_states RepositoryCheck::ClearWorker.perform_async # rubocop:disable CodeReuse/Worker redirect_to( general_admin_application_settings_path, notice: _('Started asynchronous removal of all repository check states.') ) end |
#integrations ⇒ Object
58 59 60 61 62 63 64 |
# File 'app/controllers/admin/application_settings_controller.rb', line 58 def integrations return not_found unless instance_level_integrations? @integrations = Integration.find_or_initialize_all_non_project_specific( Integration.for_instance, include_instance_specific: true ).sort_by { |int| int.title.downcase } end |
#lets_encrypt_terms_of_service ⇒ Object
Getting ToS url requires directory api call to Let’s Encrypt which could result in 500 error/slow rendering on settings page Because of that we use separate controller action
127 128 129 |
# File 'app/controllers/admin/application_settings_controller.rb', line 127 def lets_encrypt_terms_of_service redirect_to ::Gitlab::LetsEncrypt.terms_of_service_url end |
#reset_error_tracking_access_token ⇒ Object
101 102 103 104 105 106 |
# File 'app/controllers/admin/application_settings_controller.rb', line 101 def reset_error_tracking_access_token @application_setting.reset_error_tracking_access_token! redirect_to general_admin_application_settings_path, notice: _('New error tracking access token has been generated!') end |
#reset_health_check_token ⇒ Object
95 96 97 98 99 |
# File 'app/controllers/admin/application_settings_controller.rb', line 95 def reset_health_check_token @application_setting.reset_health_check_access_token! flash[:notice] = _('New health check access token has been generated!') redirect_back_or_default end |
#reset_registration_token ⇒ Object
88 89 90 91 92 93 |
# File 'app/controllers/admin/application_settings_controller.rb', line 88 def reset_registration_token ::Ci::Runners::ResetRegistrationTokenService.new(@application_setting, current_user).execute flash[:notice] = _('New runners registration token has been generated!') redirect_to admin_runners_path end |
#reset_vscode_extension_marketplace_extension_host_domain ⇒ Object
108 109 110 111 112 113 |
# File 'app/controllers/admin/application_settings_controller.rb', line 108 def reset_vscode_extension_marketplace_extension_host_domain ::WebIde::ExtensionMarketplace.reset_extension_host_domain! redirect_to general_admin_application_settings_path(anchor: 'js-web-ide-settings'), notice: _('The Web IDE extension host domain was restored to its default value.') end |
#slack_app_manifest_download ⇒ Object
135 136 137 |
# File 'app/controllers/admin/application_settings_controller.rb', line 135 def slack_app_manifest_download send_data Slack::Manifest.to_json, type: :json, disposition: 'attachment', filename: 'slack_manifest.json' end |
#slack_app_manifest_share ⇒ Object
131 132 133 |
# File 'app/controllers/admin/application_settings_controller.rb', line 131 def slack_app_manifest_share redirect_to Slack::Manifest.share_url end |
#update ⇒ Object
66 67 68 |
# File 'app/controllers/admin/application_settings_controller.rb', line 66 def update perform_update end |
#usage_data ⇒ Object
70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 |
# File 'app/controllers/admin/application_settings_controller.rb', line 70 def usage_data return not_found unless prerecorded_service_ping_data.present? respond_to do |format| format.html do usage_data_json = Gitlab::Json.pretty_generate(prerecorded_service_ping_data) render html: Gitlab::Highlight.highlight('payload.json', usage_data_json, language: 'json') end format.json do Gitlab::InternalEvents.track_event('usage_data_download_payload_clicked', user: current_user) render json: Gitlab::Json.dump(prerecorded_service_ping_data) end end end |