universal-track-manager 0.7.7 → 0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: ab3d168614b9fa1d687a98de280261c1c0940e4ad106507d6179fdcbfd3fa612
4
- data.tar.gz: acce233bb495d17f8e86542ee5317d281a6e254f31804549dc2491aa392999c5
3
+ metadata.gz: 3502ff3b3d704f5b5dfeb4c13e58ce428440cbadcc919e4520ff52b984c48d67
4
+ data.tar.gz: 9bea1196733eb210f5a6f13d6cf9ea6d611ef2a4e4adf026632f1d96a917994d
5
5
  SHA512:
6
- metadata.gz: 12f3938c8acb97e7cada43aa75e7dc7656df2a27929d3e7ee7b5cd258b38dd71afa9ca99dfe05dac91fba9d9a430b73132ebf8034ba20fa266810d21664a9a91
7
- data.tar.gz: 774fde495321f64ee56ffc1ed039ea3ec25ee8d8c92d4e2e68bccd342f9171c280a4d78d0b6d199ed34f52ab26cf22485e2f1ff196d7587a09505f6b19ef0f33
6
+ metadata.gz: 7366b077ae76ae1d634281dec71e89dfbecb126d2e025f98339f933db911067d17e3a9c1b1274c2c035d482c37cf458e463561733521987f4fb952ee3a5f6ed6
7
+ data.tar.gz: 84d7cdfa15d0fd2a7e2b6fb7480352e9573707c6170c32a3ea58baba35f930d74ef1f2dee4317c677bc9891eedfbe1375351d147940515e4bee02ee4216c7125
@@ -14,6 +14,7 @@ class CreateUniversalTrackManagerTables < ActiveRecord::Migration<%= migration_v
14
14
  # this table gets automatically populated by inbound traffic
15
15
  #GENERATOR INSERTS CAMPAIGN COLUMNS HERE
16
16
  t.string :sha1, limit: 40
17
+ t.boolean :gclid_present
17
18
  t.timestamps
18
19
  end
19
20
 
@@ -4,6 +4,7 @@ UniversalTrackManager.configure do |config|
4
4
  config.track_user_agent = true
5
5
  #GENERATOR INSERTS CAMPAIGN COLUMN CONFIG HERE
6
6
 
7
- # config.track_referrer = false
8
-
7
+ config.campaign_columns = 'utm_source,utm_medium,utm_campaign,utm_term,utm_content'
8
+ # config.track_referrer = true
9
+ # config.track_gclid_present = true # be sure to add gclid to campaign_columns
9
10
  end
@@ -55,14 +55,28 @@ module UniversalTrackManagerConcern
55
55
  begin
56
56
  existing_visit = UniversalTrackManager::Visit.find(session['visit_id'])
57
57
 
58
- evict_visit!(existing_visit) if any_utm_params? && !existing_visit.matches_all_utms?(permitted_utm_params)
58
+ if any_utm_params? && !existing_visit.matches_all_utms?(permitted_utm_params)
59
+ evict_visit!(existing_visit)
60
+ end
59
61
 
60
- evict_visit!(existing_visit) if existing_visit.ip_v4_address != ip_address
61
- evict_visit!(existing_visit) if existing_visit.browser && existing_visit.browser.name != user_agent
62
+ if existing_visit.ip_v4_address != ip_address
63
+ evict_visit!(existing_visit)
62
64
 
63
- if UniversalTrackManager.track_http_referrer? && existing_visit.referer != request.referer
65
+ end
66
+
67
+ if existing_visit.browser &&
68
+ existing_visit.browser.name != user_agent
64
69
  evict_visit!(existing_visit)
65
70
  end
71
+
72
+
73
+ if (UniversalTrackManager.track_http_referrer? &&
74
+ (request.referrer &&
75
+ !request.referrer.include?(request.host) &&
76
+ existing_visit.referer != request.referer))
77
+ evict_visit!(existing_visit)
78
+ end
79
+
66
80
  existing_visit.update_columns(:last_pageload => Time.now) if !@visit_evicted
67
81
  rescue ActiveRecord::RecordNotFound
68
82
  # this happens if the session table is cleared or if the record in the session
@@ -89,10 +103,17 @@ module UniversalTrackManagerConcern
89
103
  return nil if ! UniversalTrackManager.track_utms?
90
104
  gen_sha1 = gen_campaign_key(permitted_utm_params)
91
105
 
92
- # find_or_create_by finding only by sha1 would be nice here, but how to do so with a dynamic set of columns?
93
- # we've got a small chance of dups here due to the non-atomic find/create and sha1, but that's ok for this application.
94
- c = UniversalTrackManager::Campaign.find_by(sha1: gen_sha1)
95
- c ||= UniversalTrackManager::Campaign.create(*(permitted_utm_params.merge({"sha1": gen_sha1})))
106
+
107
+ gclid_present = UniversalTrackManager.track_gclid_present? && permitted_utm_params[:gclid].present?
108
+
109
+ campaign = UniversalTrackManager::Campaign.find_by(sha1: gen_sha1,
110
+ gclid_present: gclid_present)
111
+
112
+ without_glcid = permitted_utm_params.tap{|x| x.delete("gclid")}
113
+ campaign ||= UniversalTrackManager::Campaign.create(*(without_glcid.merge({
114
+ sha1: gen_sha1,
115
+ gclid_present: gclid_present
116
+ })))
96
117
  end
97
118
 
98
119
  def gen_campaign_key(params)
@@ -4,9 +4,15 @@ module UniversalTrackManager
4
4
  require "railtie.rb" if defined?(Rails)
5
5
 
6
6
  class Settings
7
- attr_accessor :track_ips, :track_utms, :track_user_agent, :track_http_referrer, :campaign_columns
7
+ attr_accessor :track_ips,
8
+ :track_utms,
9
+ :track_user_agent,
10
+ :track_http_referrer,
11
+ :campaign_columns,
12
+ :track_gclid_present
8
13
  end
9
14
 
15
+
10
16
  def self.configure(&block)
11
17
  @_settings = Settings.new
12
18
 
@@ -29,6 +35,10 @@ module UniversalTrackManager
29
35
  @_settings.track_http_referrer
30
36
  end
31
37
 
38
+ def self.track_gclid_present?
39
+ @_settings.track_gclid_present
40
+ end
41
+
32
42
  def self.campaign_column_names
33
43
  @campaign_column_names ||= @_settings.campaign_columns.split(',')
34
44
  end
data/lib/version.rb CHANGED
@@ -1,3 +1,3 @@
1
1
  module UniversalTrackManager
2
- VERSION = "0.7.7"
2
+ VERSION = "0.8"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: universal-track-manager
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.7.7
4
+ version: '0.8'
5
5
  platform: ruby
6
6
  authors:
7
7
  - Jason Fleetwood-Boldt
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-12-17 00:00:00.000000000 Z
11
+ date: 2025-02-19 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rails