debian-mirror-gitlab/app/services/submit_usage_ping_service.rb

48 lines
1.6 KiB
Ruby
Raw Normal View History

2018-11-18 11:00:15 +05:30
# frozen_string_literal: true
2017-09-10 17:25:29 +05:30
class SubmitUsagePingService
2019-12-04 20:38:33 +05:30
URL = 'https://version.gitlab.com/usage_data'
2017-09-10 17:25:29 +05:30
METRICS = %w[leader_issues instance_issues percentage_issues leader_notes instance_notes
percentage_notes leader_milestones instance_milestones percentage_milestones
leader_boards instance_boards percentage_boards leader_merge_requests
instance_merge_requests percentage_merge_requests leader_ci_pipelines
instance_ci_pipelines percentage_ci_pipelines leader_environments instance_environments
percentage_environments leader_deployments instance_deployments percentage_deployments
leader_projects_prometheus_active instance_projects_prometheus_active
percentage_projects_prometheus_active leader_service_desk_issues instance_service_desk_issues
percentage_service_desk_issues].freeze
def execute
2018-03-17 18:26:18 +05:30
return false unless Gitlab::CurrentSettings.usage_ping_enabled?
2018-11-20 20:47:30 +05:30
return false if User.single_user&.requires_usage_stats_consent?
2017-09-10 17:25:29 +05:30
2018-03-26 14:24:53 +05:30
response = Gitlab::HTTP.post(
2017-09-10 17:25:29 +05:30
URL,
body: Gitlab::UsageData.to_json(force_refresh: true),
2018-03-26 14:24:53 +05:30
allow_local_requests: true,
2017-09-10 17:25:29 +05:30
headers: { 'Content-type' => 'application/json' }
)
store_metrics(response)
true
2018-03-26 14:24:53 +05:30
rescue Gitlab::HTTP::Error => e
2020-06-23 00:09:42 +05:30
Gitlab::AppLogger.info("Unable to contact GitLab, Inc.: #{e}")
2017-09-10 17:25:29 +05:30
false
end
private
def store_metrics(response)
2020-03-13 15:44:24 +05:30
metrics = response['conv_index'] || response['dev_ops_score']
return unless metrics.present?
2017-09-10 17:25:29 +05:30
2020-01-01 13:55:28 +05:30
DevOpsScore::Metric.create!(
2020-03-13 15:44:24 +05:30
metrics.slice(*METRICS)
2017-09-10 17:25:29 +05:30
)
end
end