debian-mirror-gitlab/lib/gitlab/tracking/destinations/snowplow.rb

119 lines
3.3 KiB
Ruby
Raw Normal View History

2021-01-29 00:20:46 +05:30
# frozen_string_literal: true
require 'snowplow-tracker'
module Gitlab
module Tracking
module Destinations
class Snowplow < Base
extend ::Gitlab::Utils::Override
2022-01-26 12:08:38 +05:30
SNOWPLOW_NAMESPACE = 'gl'
2021-01-29 00:20:46 +05:30
override :event
def event(category, action, label: nil, property: nil, value: nil, context: nil)
return unless enabled?
2023-03-04 22:38:38 +05:30
tracker.track_struct_event(
category: category,
action: action,
label: label,
property: property,
value: value,
context: context,
tstamp: (Time.now.to_f * 1000).to_i
)
2021-09-30 23:02:18 +05:30
increment_total_events_counter
2021-01-29 00:20:46 +05:30
end
2021-12-11 22:18:48 +05:30
def options(group)
additional_features = Feature.enabled?(:additional_snowplow_tracking, group, type: :ops)
{
2022-01-26 12:08:38 +05:30
namespace: SNOWPLOW_NAMESPACE,
2021-12-11 22:18:48 +05:30
hostname: hostname,
cookie_domain: cookie_domain,
app_id: app_id,
form_tracking: additional_features,
link_click_tracking: additional_features
}.transform_keys! { |key| key.to_s.camelize(:lower).to_sym }
end
2022-01-26 12:08:38 +05:30
def enabled?
Gitlab::CurrentSettings.snowplow_enabled?
end
2021-12-11 22:18:48 +05:30
def hostname
Gitlab::CurrentSettings.snowplow_collector_hostname
end
2021-01-29 00:20:46 +05:30
private
2021-12-11 22:18:48 +05:30
def app_id
Gitlab::CurrentSettings.snowplow_app_id
end
def protocol
'https'
end
def cookie_domain
Gitlab::CurrentSettings.snowplow_cookie_domain
end
2021-01-29 00:20:46 +05:30
def tracker
@tracker ||= SnowplowTracker::Tracker.new(
2023-03-04 22:38:38 +05:30
emitters: [emitter],
subject: SnowplowTracker::Subject.new,
namespace: SNOWPLOW_NAMESPACE,
app_id: app_id
2021-01-29 00:20:46 +05:30
)
end
def emitter
SnowplowTracker::AsyncEmitter.new(
2023-03-04 22:38:38 +05:30
endpoint: hostname,
options: {
protocol: protocol,
on_success: method(:increment_successful_events_emissions),
on_failure: method(:failure_callback)
}
2021-01-29 00:20:46 +05:30
)
end
2021-09-30 23:02:18 +05:30
def failure_callback(success_count, failures)
increment_successful_events_emissions(success_count)
increment_failed_events_emissions(failures.size)
log_failures(failures)
end
def increment_failed_events_emissions(value)
Gitlab::Metrics.counter(
:gitlab_snowplow_failed_events_total,
'Number of failed Snowplow events emissions'
).increment({}, value.to_i)
end
def increment_successful_events_emissions(value)
Gitlab::Metrics.counter(
:gitlab_snowplow_successful_events_total,
'Number of successful Snowplow events emissions'
).increment({}, value.to_i)
end
def increment_total_events_counter
Gitlab::Metrics.counter(
:gitlab_snowplow_events_total,
'Number of Snowplow events'
).increment
end
def log_failures(failures)
failures.each do |failure|
Gitlab::AppLogger.error("#{failure["se_ca"]} #{failure["se_ac"]} failed to be reported to collector at #{hostname}")
end
end
2021-01-29 00:20:46 +05:30
end
end
end
end