Commit 42bba3a9 authored by Philip Cunningham's avatar Philip Cunningham

Use new Sanitizable concern in ApplicationSetting

- Includes and uses new concern
- Adds specs to capture behaviour
- Fix bug in view that uses wrong action
parent 9bc09614
...@@ -6,6 +6,7 @@ class ApplicationSetting < ApplicationRecord ...@@ -6,6 +6,7 @@ class ApplicationSetting < ApplicationRecord
include TokenAuthenticatable include TokenAuthenticatable
include ChronicDurationAttribute include ChronicDurationAttribute
include IgnorableColumns include IgnorableColumns
include Sanitizable
ignore_columns %i[elasticsearch_shards elasticsearch_replicas], remove_with: '14.4', remove_after: '2021-09-22' ignore_columns %i[elasticsearch_shards elasticsearch_replicas], remove_with: '14.4', remove_after: '2021-09-22'
ignore_column :seat_link_enabled, remove_with: '14.4', remove_after: '2021-09-22' ignore_column :seat_link_enabled, remove_with: '14.4', remove_after: '2021-09-22'
...@@ -32,6 +33,8 @@ class ApplicationSetting < ApplicationRecord ...@@ -32,6 +33,8 @@ class ApplicationSetting < ApplicationRecord
alias_attribute :instance_group_id, :instance_administrators_group_id alias_attribute :instance_group_id, :instance_administrators_group_id
alias_attribute :instance_administrators_group, :instance_group alias_attribute :instance_administrators_group, :instance_group
sanitizes! :default_branch_name
def self.kroki_formats_attributes def self.kroki_formats_attributes
{ {
blockdiag: { blockdiag: {
...@@ -599,7 +602,7 @@ class ApplicationSetting < ApplicationRecord ...@@ -599,7 +602,7 @@ class ApplicationSetting < ApplicationRecord
before_validation :ensure_uuid! before_validation :ensure_uuid!
before_validation :coerce_repository_storages_weighted, if: :repository_storages_weighted_changed? before_validation :coerce_repository_storages_weighted, if: :repository_storages_weighted_changed?
before_validation :sanitize_default_branch_name before_validation :normalize_default_branch_name
before_save :ensure_runners_registration_token before_save :ensure_runners_registration_token
before_save :ensure_health_check_access_token before_save :ensure_health_check_access_token
...@@ -629,12 +632,8 @@ class ApplicationSetting < ApplicationRecord ...@@ -629,12 +632,8 @@ class ApplicationSetting < ApplicationRecord
!!(sourcegraph_url =~ %r{\Ahttps://(www\.)?sourcegraph\.com}) !!(sourcegraph_url =~ %r{\Ahttps://(www\.)?sourcegraph\.com})
end end
def sanitize_default_branch_name def normalize_default_branch_name
self.default_branch_name = if default_branch_name.blank? self.default_branch_name = default_branch_name.presence
nil
else
Sanitize.fragment(self.default_branch_name)
end
end end
def instance_review_permitted? def instance_review_permitted?
......
= form_for @application_setting, url: general_admin_application_settings_path(anchor: 'js-default-branch-name'), html: { class: 'fieldset-form' } do |f| = form_for @application_setting, url: repository_admin_application_settings_path(anchor: 'js-default-branch-name'), html: { class: 'fieldset-form' } do |f|
= form_errors(@application_setting) = form_errors(@application_setting)
- fallback_branch_name = "<code>#{Gitlab::DefaultBranch.value}</code>" - fallback_branch_name = "<code>#{Gitlab::DefaultBranch.value}</code>"
......
...@@ -7,6 +7,8 @@ RSpec.describe ApplicationSetting do ...@@ -7,6 +7,8 @@ RSpec.describe ApplicationSetting do
subject(:setting) { described_class.create_from_defaults } subject(:setting) { described_class.create_from_defaults }
it_behaves_like 'sanitizable', :application_setting, %i[default_branch_name]
it { include(CacheableAttributes) } it { include(CacheableAttributes) }
it { include(ApplicationSettingImplementation) } it { include(ApplicationSettingImplementation) }
it { expect(described_class.current_without_cache).to eq(described_class.last) } it { expect(described_class.current_without_cache).to eq(described_class.last) }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment