Class: Rack::Tracker::Handler
- Inherits:
-
Object
- Object
- Rack::Tracker::Handler
- Includes:
- JavaScriptHelper
- Defined in:
- lib/rack/tracker/handler.rb
Direct Known Subclasses
Bing, Criteo, Drift, Facebook, FacebookPixel, GoSquared, GoogleAdwordsConversion, GoogleAnalytics, GoogleGlobal, GoogleTagManager, Hotjar, Hubspot, Vwo, Zanox
Constant Summary
Constants included from JavaScriptHelper
JavaScriptHelper::JS_ESCAPE_MAP
Instance Attribute Summary collapse
-
#env ⇒ Object
Returns the value of attribute env.
-
#options ⇒ Object
Returns the value of attribute options.
Class Method Summary collapse
- .process_track(env, method_name, *args, &block) ⇒ Object
-
.track(name, *event) ⇒ Object
overwrite me in the handler subclass if you need more control over the event.
Instance Method Summary collapse
-
#dnt_header_opt_out? ⇒ Boolean
the request has set the DO NOT TRACK (DNT) and has opted to get not tracked (DNT=1).
- #events ⇒ Object
- #handler_name ⇒ Object
-
#initialize(env, options = {}) ⇒ Handler
constructor
A new instance of Handler.
- #inject(response) ⇒ Object
- #render ⇒ Object
- #tracker_options ⇒ Object
- #write_event(event) ⇒ Object
Methods included from JavaScriptHelper
Constructor Details
#initialize(env, options = {}) ⇒ Handler
Returns a new instance of Handler.
25 26 27 28 29 |
# File 'lib/rack/tracker/handler.rb', line 25 def initialize(env, = {}) self.env = env self. = self.position = [:position] if .has_key?(:position) end |
Instance Attribute Details
#env ⇒ Object
Returns the value of attribute env.
20 21 22 |
# File 'lib/rack/tracker/handler.rb', line 20 def env @env end |
#options ⇒ Object
Returns the value of attribute options.
19 20 21 |
# File 'lib/rack/tracker/handler.rb', line 19 def @options end |
Class Method Details
.process_track(env, method_name, *args, &block) ⇒ Object
3 4 5 |
# File 'lib/rack/tracker/handler.rb', line 3 def process_track(env, method_name, *args, &block) new(env).write_event(track(method_name, *args, &block)) end |
.track(name, *event) ⇒ Object
overwrite me in the handler subclass if you need more control over the event
8 9 10 |
# File 'lib/rack/tracker/handler.rb', line 8 def track(name, *event) { name.to_s => [event.last.merge('class_name' => event.first.to_s.classify)] } end |
Instance Method Details
#dnt_header_opt_out? ⇒ Boolean
the request has set the DO NOT TRACK (DNT) and has opted to get not tracked (DNT=1)
80 81 82 |
# File 'lib/rack/tracker/handler.rb', line 80 def dnt_header_opt_out? self.env['HTTP_DNT'] && self.env['HTTP_DNT'].to_s == '1' end |
#events ⇒ Object
31 32 33 34 |
# File 'lib/rack/tracker/handler.rb', line 31 def events events = env.fetch('tracker', {})[handler_name] || [] events.map { |ev| "#{self.class}::#{ev['class_name']}".constantize.new(ev.except('class_name')) } end |
#handler_name ⇒ Object
64 65 66 |
# File 'lib/rack/tracker/handler.rb', line 64 def handler_name self.class.name.demodulize.underscore end |
#inject(response) ⇒ Object
40 41 42 43 44 45 46 47 48 49 50 51 52 53 |
# File 'lib/rack/tracker/handler.rb', line 40 def inject(response) # default to not inject this tracker if the DNT HTTP header is set # if the DO_NOT_RESPECT_DNT_HEADER config is set the DNT header is ignored :( - please do respect the DNT header! if self.dnt_header_opt_out? && !self..has_key?(:DO_NOT_RESPECT_DNT_HEADER) return response end # Sub! is enough, in well formed html there's only one head or body tag. # Block syntax need to be used, otherwise backslashes in input will mess the output. # @see http://stackoverflow.com/a/4149087/518204 and https://github.com/railslove/rack-tracker/issues/50 response.sub! %r{</#{self.position}>} do |m| self.render << m.to_s end response end |
#render ⇒ Object
36 37 38 |
# File 'lib/rack/tracker/handler.rb', line 36 def render Tilt.new(File.join(File.dirname(__FILE__), handler_name, 'template', "#{handler_name}.erb") ).render(self) end |
#tracker_options ⇒ Object
68 69 70 71 72 73 74 75 76 77 |
# File 'lib/rack/tracker/handler.rb', line 68 def @_tracker_options ||= {}.tap do || .slice(*).each do |key, value| option_value = value.respond_to?(:call) ? value.call(env) : value unless option_value.nil? [tracker_option_key(key)] = tracker_option_value(option_value) end end end end |
#write_event(event) ⇒ Object
55 56 57 58 59 60 61 62 |
# File 'lib/rack/tracker/handler.rb', line 55 def write_event(event) event.deep_stringify_keys! # for consistent hash access use strings (keys from the session are always strings anyway) if env.key?('tracker') self.env['tracker'].deep_merge!(event) { |key, old, new| Array.wrap(old) + Array.wrap(new) } else self.env['tracker'] = event end end |