mirror of
https://github.com/codeninjasllc/discourse.git
synced 2025-02-17 04:01:29 -05:00
SECURITY: disable user entered badge SQL by default
- Hidden site settings now must be change via rails console
This commit is contained in:
parent
cb3afd11b4
commit
c6dbaca0dc
6 changed files with 110 additions and 41 deletions
|
@ -60,6 +60,7 @@
|
||||||
{{/if}}
|
{{/if}}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{{#if siteSettings.enable_badge_sql}}
|
||||||
<div>
|
<div>
|
||||||
<label for="query">{{i18n 'admin.badges.query'}}</label>
|
<label for="query">{{i18n 'admin.badges.query'}}</label>
|
||||||
{{textarea name="query" value=buffered.query disabled=readOnly}}
|
{{textarea name="query" value=buffered.query disabled=readOnly}}
|
||||||
|
@ -97,6 +98,7 @@
|
||||||
disabled=readOnly}}
|
disabled=readOnly}}
|
||||||
</div>
|
</div>
|
||||||
{{/if}}
|
{{/if}}
|
||||||
|
{{/if}}
|
||||||
|
|
||||||
<div>
|
<div>
|
||||||
<label>
|
<label>
|
||||||
|
|
|
@ -15,6 +15,12 @@ class Admin::BadgesController < Admin::AdminController
|
||||||
end
|
end
|
||||||
|
|
||||||
def preview
|
def preview
|
||||||
|
|
||||||
|
unless SiteSetting.enable_badge_sql
|
||||||
|
render json: "preview not allowed", status: 403
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
render json: BadgeGranter.preview(params[:sql],
|
render json: BadgeGranter.preview(params[:sql],
|
||||||
target_posts: params[:target_posts] == "true",
|
target_posts: params[:target_posts] == "true",
|
||||||
explain: params[:explain] == "true",
|
explain: params[:explain] == "true",
|
||||||
|
@ -95,6 +101,8 @@ class Admin::BadgesController < Admin::AdminController
|
||||||
allowed = Badge.column_names.map(&:to_sym)
|
allowed = Badge.column_names.map(&:to_sym)
|
||||||
allowed -= [:id, :created_at, :updated_at, :grant_count]
|
allowed -= [:id, :created_at, :updated_at, :grant_count]
|
||||||
allowed -= Badge.protected_system_fields if badge.system?
|
allowed -= Badge.protected_system_fields if badge.system?
|
||||||
|
allowed -= [:query] unless SiteSetting.enable_badge_sql
|
||||||
|
|
||||||
params.permit(*allowed)
|
params.permit(*allowed)
|
||||||
|
|
||||||
allowed.each do |key|
|
allowed.each do |key|
|
||||||
|
@ -103,7 +111,9 @@ class Admin::BadgesController < Admin::AdminController
|
||||||
|
|
||||||
# Badge query contract checks
|
# Badge query contract checks
|
||||||
begin
|
begin
|
||||||
|
if SiteSetting.enable_badge_sql
|
||||||
BadgeGranter.contract_checks!(badge.query, { target_posts: badge.target_posts, trigger: badge.trigger })
|
BadgeGranter.contract_checks!(badge.query, { target_posts: badge.target_posts, trigger: badge.trigger })
|
||||||
|
end
|
||||||
rescue => e
|
rescue => e
|
||||||
errors << e.message
|
errors << e.message
|
||||||
raise ActiveRecord::Rollback
|
raise ActiveRecord::Rollback
|
||||||
|
|
|
@ -10,6 +10,10 @@ class Admin::SiteSettingsController < Admin::AdminController
|
||||||
value = params[id]
|
value = params[id]
|
||||||
value.strip! if value.is_a?(String)
|
value.strip! if value.is_a?(String)
|
||||||
begin
|
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)
|
SiteSetting.set_and_log(id, value, current_user)
|
||||||
render nothing: true
|
render nothing: true
|
||||||
rescue Discourse::InvalidParameters => e
|
rescue Discourse::InvalidParameters => e
|
||||||
|
|
|
@ -199,17 +199,19 @@ basic:
|
||||||
fixed_category_positions:
|
fixed_category_positions:
|
||||||
client: true
|
client: true
|
||||||
default: false
|
default: false
|
||||||
|
|
||||||
fixed_category_positions_on_create:
|
fixed_category_positions_on_create:
|
||||||
client: true
|
client: true
|
||||||
default: false
|
default: false
|
||||||
|
|
||||||
show_subcategory_list:
|
show_subcategory_list:
|
||||||
default: false
|
default: false
|
||||||
client: true
|
client: true
|
||||||
enable_badges:
|
enable_badges:
|
||||||
client: true
|
client: true
|
||||||
default: true
|
default: true
|
||||||
|
enable_badge_sql:
|
||||||
|
client: true
|
||||||
|
default: false
|
||||||
|
hidden: true
|
||||||
enable_whispers:
|
enable_whispers:
|
||||||
client: true
|
client: true
|
||||||
default: false
|
default: false
|
||||||
|
|
|
@ -13,6 +13,19 @@ describe Admin::BadgesController do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'preview' do
|
||||||
|
it 'allows preview enable_badge_sql is enabled' do
|
||||||
|
SiteSetting.enable_badge_sql = true
|
||||||
|
result = xhr :get, :preview, sql: 'select id as user_id, created_at granted_at from users'
|
||||||
|
expect(JSON.parse(result.body)["grant_count"]).to be > 0
|
||||||
|
end
|
||||||
|
it 'does not allow anything if enable_badge_sql is disabled' do
|
||||||
|
SiteSetting.enable_badge_sql = false
|
||||||
|
result = xhr :get, :preview, sql: 'select id as user_id, created_at granted_at from users'
|
||||||
|
expect(result.status).to eq(403)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
context '.save_badge_groupings' do
|
context '.save_badge_groupings' do
|
||||||
|
|
||||||
it 'can save badge groupings' do
|
it 'can save badge groupings' do
|
||||||
|
@ -62,14 +75,45 @@ describe Admin::BadgesController do
|
||||||
end
|
end
|
||||||
|
|
||||||
context '.update' do
|
context '.update' do
|
||||||
it 'returns success' do
|
|
||||||
xhr :put, :update, id: badge.id, name: "123456", badge_type_id: badge.badge_type_id, allow_title: false, multiple_grant: false, enabled: true
|
it 'does not allow query updates if badge_sql is disabled' do
|
||||||
|
badge.query = "select 123"
|
||||||
|
badge.save
|
||||||
|
|
||||||
|
SiteSetting.enable_badge_sql = false
|
||||||
|
|
||||||
|
xhr :put, :update,
|
||||||
|
id: badge.id,
|
||||||
|
name: "123456",
|
||||||
|
query: "select id user_id, created_at granted_at from users",
|
||||||
|
badge_type_id: badge.badge_type_id,
|
||||||
|
allow_title: false,
|
||||||
|
multiple_grant: false,
|
||||||
|
enabled: true
|
||||||
|
|
||||||
expect(response).to be_success
|
expect(response).to be_success
|
||||||
|
badge.reload
|
||||||
|
expect(badge.name).to eq('123456')
|
||||||
|
expect(badge.query).to eq('select 123')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'updates the badge' do
|
it 'updates the badge' do
|
||||||
xhr :put, :update, id: badge.id, name: "123456", badge_type_id: badge.badge_type_id, allow_title: false, multiple_grant: true, enabled: true
|
SiteSetting.enable_badge_sql = true
|
||||||
expect(badge.reload.name).to eq('123456')
|
sql = "select id user_id, created_at granted_at from users"
|
||||||
|
|
||||||
|
xhr :put, :update,
|
||||||
|
id: badge.id,
|
||||||
|
name: "123456",
|
||||||
|
query: sql,
|
||||||
|
badge_type_id: badge.badge_type_id,
|
||||||
|
allow_title: false,
|
||||||
|
multiple_grant: false,
|
||||||
|
enabled: true
|
||||||
|
|
||||||
|
expect(response).to be_success
|
||||||
|
badge.reload
|
||||||
|
expect(badge.name).to eq('123456')
|
||||||
|
expect(badge.query).to eq(sql)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -46,6 +46,13 @@ describe Admin::SiteSettingsController do
|
||||||
xhr :put, :update, id: 'test_setting', test_setting: 'hello'
|
xhr :put, :update, id: 'test_setting', test_setting: 'hello'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it 'does not allow changing of hidden settings' do
|
||||||
|
SiteSetting.setting(:hidden_setting, "hidden", hidden: true)
|
||||||
|
result = xhr :put, :update, id: 'hidden_setting', hidden_setting: 'not allowed'
|
||||||
|
expect(SiteSetting.hidden_setting).to eq("hidden")
|
||||||
|
expect(result.status).to eq(422)
|
||||||
|
end
|
||||||
|
|
||||||
it 'fails when a setting does not exist' do
|
it 'fails when a setting does not exist' do
|
||||||
expect {
|
expect {
|
||||||
xhr :put, :update, id: 'provider', provider: 'gotcha'
|
xhr :put, :update, id: 'provider', provider: 'gotcha'
|
||||||
|
|
Loading…
Reference in a new issue