Commit 165b80bd authored by Markus Koller's avatar Markus Koller

Don't allow creating integrations with base classes

parent 35ad14f7
...@@ -29,6 +29,15 @@ class Integration < ApplicationRecord ...@@ -29,6 +29,15 @@ class Integration < ApplicationRecord
mock_ci mock_monitoring mock_ci mock_monitoring
].freeze ].freeze
# Base classes which aren't actual integrations.
BASE_CLASSES = %w[
Integrations::BaseChatNotification
Integrations::BaseCi
Integrations::BaseIssueTracker
Integrations::BaseMonitoring
Integrations::BaseSlashCommands
].freeze
serialize :properties, JSON # rubocop:disable Cop/ActiveRecordSerialize serialize :properties, JSON # rubocop:disable Cop/ActiveRecordSerialize
attribute :type, Gitlab::Integrations::StiType.new attribute :type, Gitlab::Integrations::StiType.new
...@@ -59,7 +68,7 @@ class Integration < ApplicationRecord ...@@ -59,7 +68,7 @@ class Integration < ApplicationRecord
validates :project_id, presence: true, unless: -> { template? || instance_level? || group_level? } validates :project_id, presence: true, unless: -> { template? || instance_level? || group_level? }
validates :group_id, presence: true, unless: -> { template? || instance_level? || project_level? } validates :group_id, presence: true, unless: -> { template? || instance_level? || project_level? }
validates :project_id, :group_id, absence: true, if: -> { template? || instance_level? } validates :project_id, :group_id, absence: true, if: -> { template? || instance_level? }
validates :type, presence: true validates :type, presence: true, exclusion: BASE_CLASSES
validates :type, uniqueness: { scope: :template }, if: :template? validates :type, uniqueness: { scope: :template }, if: :template?
validates :type, uniqueness: { scope: :instance }, if: :instance_level? validates :type, uniqueness: { scope: :instance }, if: :instance_level?
validates :type, uniqueness: { scope: :project_id }, if: :project_level? validates :type, uniqueness: { scope: :project_id }, if: :project_level?
......
...@@ -18,6 +18,7 @@ RSpec.describe Integration do ...@@ -18,6 +18,7 @@ RSpec.describe Integration do
describe 'validations' do describe 'validations' do
it { is_expected.to validate_presence_of(:type) } it { is_expected.to validate_presence_of(:type) }
it { is_expected.to validate_exclusion_of(:type).in_array(described_class::BASE_CLASSES) }
where(:project_id, :group_id, :template, :instance, :valid) do where(:project_id, :group_id, :template, :instance, :valid) do
1 | nil | false | false | true 1 | nil | false | false | true
......
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