debian-mirror-gitlab/app/models/grafana_integration.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

61 lines
1.3 KiB
Ruby
Raw Normal View History

2019-12-21 20:55:43 +05:30
# frozen_string_literal: true
class GrafanaIntegration < ApplicationRecord
belongs_to :project
attr_encrypted :token,
2022-08-27 11:52:29 +05:30
mode: :per_attribute_iv,
2019-12-21 20:55:43 +05:30
algorithm: 'aes-256-gcm',
2022-08-27 11:52:29 +05:30
key: Settings.attr_encrypted_db_key_base_32
2019-12-21 20:55:43 +05:30
2020-02-01 01:16:34 +05:30
before_validation :check_token_changes
2019-12-21 20:55:43 +05:30
validates :grafana_url,
length: { maximum: 1024 },
addressable_url: { enforce_sanitization: true, ascii_only: true }
2020-02-01 01:16:34 +05:30
validates :encrypted_token, :project, presence: true
2019-12-21 20:55:43 +05:30
2019-12-26 22:10:19 +05:30
validates :enabled, inclusion: { in: [true, false] }
2022-07-29 17:44:30 +05:30
before_validation :reset_token
2019-12-26 22:10:19 +05:30
scope :enabled, -> { where(enabled: true) }
2019-12-21 20:55:43 +05:30
def client
2019-12-26 22:10:19 +05:30
return unless enabled?
2019-12-21 20:55:43 +05:30
@client ||= ::Grafana::Client.new(api_url: grafana_url.chomp('/'), token: token)
end
2020-02-01 01:16:34 +05:30
def masked_token
mask(encrypted_token)
end
def masked_token_was
mask(encrypted_token_was)
end
private
2022-07-29 17:44:30 +05:30
def reset_token
if grafana_url_changed? && !encrypted_token_changed?
self.token = nil
end
end
2020-02-01 01:16:34 +05:30
def token
decrypt(:token, encrypted_token)
end
def check_token_changes
return unless [encrypted_token_was, masked_token_was].include?(token)
clear_attribute_changes [:token, :encrypted_token, :encrypted_token_iv]
end
def mask(token)
token&.squish&.gsub(/./, '*')
end
2019-12-21 20:55:43 +05:30
end