mirror of
https://github.com/discourse/discourse.git
synced 2024-12-16 03:13:43 +08:00
c6dbaca0dc
- Hidden site settings now must be change via rails console
25 lines
732 B
Ruby
25 lines
732 B
Ruby
class Admin::SiteSettingsController < Admin::AdminController
|
|
|
|
def index
|
|
render_json_dump(site_settings: SiteSetting.all_settings, diags: SiteSetting.diags)
|
|
end
|
|
|
|
def update
|
|
params.require(:id)
|
|
id = params[:id]
|
|
value = params[id]
|
|
value.strip! if value.is_a?(String)
|
|
begin
|
|
# note, as of Ruby 2.3 symbols are GC'd so this is considered safe
|
|
if SiteSetting.hidden_settings.include?(id.to_sym)
|
|
raise Discourse::InvalidParameters, "You are not allowed to change hidden settings"
|
|
end
|
|
SiteSetting.set_and_log(id, value, current_user)
|
|
render nothing: true
|
|
rescue Discourse::InvalidParameters => e
|
|
render json: {errors: [e.message]}, status: 422
|
|
end
|
|
end
|
|
|
|
end
|