mirror of
https://github.com/discourse/discourse.git
synced 2024-11-24 15:29:39 +08:00
9be70a22cd
This removes all uses of both `send` and `public_send` from consumers of SiteSetting and instead introduces a `get` helper for dynamic lookup This leads to much cleaner and safer code long term as we are always explicit to test that a site setting is really there before sending an arbitrary string to the class It also removes a couple of risky stubs from the auth provider test
19 lines
727 B
Ruby
19 lines
727 B
Ruby
module Jobs
|
|
class EnableBootstrapMode < Jobs::Base
|
|
sidekiq_options queue: 'critical'
|
|
|
|
def execute(args)
|
|
raise Discourse::InvalidParameters.new(:user_id) unless args[:user_id].present?
|
|
return if SiteSetting.bootstrap_mode_enabled
|
|
|
|
user = User.find_by(id: args[:user_id])
|
|
return unless user.is_singular_admin?
|
|
|
|
# let's enable bootstrap mode settings
|
|
SiteSetting.set_and_log('default_trust_level', TrustLevel[1]) if SiteSetting.get('default_trust_level') == TrustLevel[0]
|
|
SiteSetting.set_and_log('default_email_digest_frequency', 1440) if SiteSetting.get('default_email_digest_frequency') == 10080
|
|
SiteSetting.set_and_log('bootstrap_mode_enabled', true)
|
|
end
|
|
end
|
|
end
|