summaryrefslogtreecommitdiff
path: root/app/models/project_feature_usage.rb
blob: 02051310af70ab7a4af8bec62a9789ec6d0b6207 (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
37
38
39
40
41
42
43
44
45
46
47
48
# frozen_string_literal: true

class ProjectFeatureUsage < ApplicationRecord
  self.primary_key = :project_id

  JIRA_DVCS_CLOUD_FIELD = 'jira_dvcs_cloud_last_sync_at'
  JIRA_DVCS_SERVER_FIELD = 'jira_dvcs_server_last_sync_at'

  belongs_to :project
  validates :project, presence: true

  scope :with_jira_dvcs_integration_enabled, -> (cloud: true) do
    where.not(jira_dvcs_integration_field(cloud: cloud) => nil)
  end

  class << self
    def jira_dvcs_integration_field(cloud: true)
      cloud ? JIRA_DVCS_CLOUD_FIELD : JIRA_DVCS_SERVER_FIELD
    end
  end

  def log_jira_dvcs_integration_usage(cloud: true)
    integration_field = self.class.jira_dvcs_integration_field(cloud: cloud)

    # The feature usage is used only once later to query the feature usage in a
    # long date range. Therefore, we just need to update the timestamp once per
    # day
    return if persisted? && updated_today?(integration_field)

    persist_jira_dvcs_usage(integration_field)
  end

  private

  def updated_today?(integration_field)
    self[integration_field].present? && self[integration_field].today?
  end

  def persist_jira_dvcs_usage(integration_field)
    assign_attributes(integration_field => Time.current)
    save
  rescue ActiveRecord::RecordNotUnique
    reset
    retry
  end
end

ProjectFeatureUsage.prepend_if_ee('EE::ProjectFeatureUsage')