blob: 2870922d90de2f22302e19f6a8a13d93e9457d34 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
# frozen_string_literal: true
module Integrations
module BaseDataFields
extend ActiveSupport::Concern
included do
# TODO: Once we rename the tables we can't rely on `table_name` anymore.
# https://gitlab.com/gitlab-org/gitlab/-/issues/331953
belongs_to :integration, inverse_of: self.table_name.to_sym, foreign_key: :integration_id
validates :integration, presence: true
end
class_methods do
def encryption_options
{
key: Settings.attr_encrypted_db_key_base_32,
encode: true,
mode: :per_attribute_iv,
algorithm: 'aes-256-gcm'
}
end
end
def activated?
!!integration&.activated?
end
def to_database_hash
as_json(
only: self.class.column_names
).except('id', 'service_id', 'integration_id', 'created_at', 'updated_at')
end
end
end
|