application_settings_controller.rb 3.2 KB
Newer Older
1
class Admin::ApplicationSettingsController < Admin::ApplicationController
2
  before_action :set_application_setting
3 4 5 6 7

  def show
  end

  def update
8 9 10 11 12 13
    if @application_setting.update_attributes(application_setting_params)
      redirect_to admin_application_settings_path,
        notice: 'Application settings saved successfully'
    else
      render :show
    end
14 15
  end

16 17 18
  def reset_runners_token
    @application_setting.reset_runners_registration_token!
    flash[:notice] = 'New runners registration token has been generated!'
19
    redirect_to admin_runners_path
20 21
  end

22 23 24 25 26 27
  def reset_health_check_token
    @application_setting.reset_health_check_access_token!
    flash[:notice] = 'New health check access token has been generated!'
    redirect_to :back
  end

28
  def clear_repository_check_states
29
    RepositoryCheck::ClearWorker.perform_async
30 31 32

    redirect_to(
      admin_application_settings_path,
33
      notice: 'Started asynchronous removal of all repository check states.'
34 35 36
    )
  end

37 38 39
  private

  def set_application_setting
40
    @application_setting = ApplicationSetting.current
41 42 43
  end

  def application_setting_params
44
    restricted_levels = params[:application_setting][:restricted_visibility_levels]
V
Vinnie Okada 已提交
45 46 47
    if restricted_levels.nil?
      params[:application_setting][:restricted_visibility_levels] = []
    else
48 49 50 51 52
      restricted_levels.map! do |level|
        level.to_i
      end
    end

53 54 55 56 57 58 59 60 61
    import_sources = params[:application_setting][:import_sources]
    if import_sources.nil?
      params[:application_setting][:import_sources] = []
    else
      import_sources.map! do |source|
        source.to_str
      end
    end

62
    enabled_oauth_sign_in_sources = params[:application_setting].delete(:enabled_oauth_sign_in_sources)
63 64 65

    params[:application_setting][:disabled_oauth_sign_in_sources] =
      AuthHelper.button_based_providers.map(&:to_s) -
66
      Array(enabled_oauth_sign_in_sources)
67

68 69
    params.require(:application_setting).permit(
      :default_projects_limit,
70
      :default_branch_protection,
71 72
      :signup_enabled,
      :signin_enabled,
73 74
      :require_two_factor_authentication,
      :two_factor_grace_period,
75 76
      :gravatar_enabled,
      :sign_in_text,
77
      :help_page_text,
78
      :home_page_url,
79
      :after_sign_out_path,
80
      :max_attachment_size,
81
      :session_expire_delay,
V
Vinnie Okada 已提交
82 83
      :default_project_visibility,
      :default_snippet_visibility,
84
      :default_group_visibility,
85
      :restricted_signup_domains_raw,
D
Dmitriy Zaporozhets 已提交
86
      :version_check_enabled,
87
      :admin_notification_email,
88
      :user_oauth_applications,
89
      :shared_runners_enabled,
90
      :shared_runners_text,
K
Kamil Trzcinski 已提交
91
      :max_artifacts_size,
92 93
      :metrics_enabled,
      :metrics_host,
94
      :metrics_port,
95 96 97
      :metrics_pool_size,
      :metrics_timeout,
      :metrics_method_call_threshold,
98
      :metrics_sample_interval,
99 100 101
      :recaptcha_enabled,
      :recaptcha_site_key,
      :recaptcha_private_key,
J
Jeroen Nijhof 已提交
102 103
      :sentry_enabled,
      :sentry_dsn,
104 105
      :akismet_enabled,
      :akismet_api_key,
106
      :email_author_in_body,
107
      :repository_checks_enabled,
108
      :metrics_packet_size,
109
      :send_user_confirmation_email,
110
      restricted_visibility_levels: [],
111 112
      import_sources: [],
      disabled_oauth_sign_in_sources: []
113 114 115
    )
  end
end