Class: Rack::Tracker::Handler

Inherits:
Object
  • Object
show all
Includes:
JavaScriptHelper
Defined in:
lib/rack/tracker/handler.rb

Constant Summary

Constants included from JavaScriptHelper

JavaScriptHelper::JS_ESCAPE_MAP

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods included from JavaScriptHelper

#escape_javascript

Constructor Details

#initialize(env, options = {}) ⇒ Handler

Returns a new instance of Handler.



22
23
24
25
26
# File 'lib/rack/tracker/handler.rb', line 22

def initialize(env, options = {})
  self.env = env
  self.options  = options
  self.position = options[:position] if options.has_key?(:position)
end

Instance Attribute Details

#envObject

Returns the value of attribute env.



17
18
19
# File 'lib/rack/tracker/handler.rb', line 17

def env
  @env
end

#optionsObject

Returns the value of attribute options.



16
17
18
# File 'lib/rack/tracker/handler.rb', line 16

def options
  @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

#eventsObject



28
29
30
31
# File 'lib/rack/tracker/handler.rb', line 28

def events
  events = env.fetch('tracker', {})[handler_name] || []
  events.map { |ev| "#{self.class}::#{ev['class_name']}".constantize.new(ev.except('class_name')) }
end

#handler_nameObject



56
57
58
# File 'lib/rack/tracker/handler.rb', line 56

def handler_name
  self.class.name.demodulize.underscore
end

#inject(response) ⇒ Object



37
38
39
40
41
42
43
44
45
# File 'lib/rack/tracker/handler.rb', line 37

def inject(response)
  # 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

#renderObject



33
34
35
# File 'lib/rack/tracker/handler.rb', line 33

def render
  Tilt.new(File.join(File.dirname(__FILE__), handler_name, 'template', "#{handler_name}.erb") ).render(self)
end

#write_event(event) ⇒ Object



47
48
49
50
51
52
53
54
# File 'lib/rack/tracker/handler.rb', line 47

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