Class: InnerPerformance::CurrentRequest

Inherits:
Object
  • Object
show all
Defined in:
lib/inner_performance/current_request.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(request_id) ⇒ CurrentRequest

Returns a new instance of CurrentRequest.



25
26
27
28
29
30
31
# File 'lib/inner_performance/current_request.rb', line 25

def initialize(request_id)
  @request_id = request_id
  @traces = []
  @ignore = Set.new
  @data = nil
  @record = nil
end

Instance Attribute Details

#dataObject

Returns the value of attribute data.



8
9
10
# File 'lib/inner_performance/current_request.rb', line 8

def data
  @data
end

#ignoreObject (readonly)

Returns the value of attribute ignore.



7
8
9
# File 'lib/inner_performance/current_request.rb', line 7

def ignore
  @ignore
end

#recordObject

Returns the value of attribute record.



9
10
11
# File 'lib/inner_performance/current_request.rb', line 9

def record
  @record
end

#request_idObject (readonly)

Returns the value of attribute request_id.



7
8
9
# File 'lib/inner_performance/current_request.rb', line 7

def request_id
  @request_id
end

#tracesObject (readonly)

Returns the value of attribute traces.



7
8
9
# File 'lib/inner_performance/current_request.rb', line 7

def traces
  @traces
end

Class Method Details

.cleanupObject



20
21
22
# File 'lib/inner_performance/current_request.rb', line 20

def cleanup
  Thread.current[:ip_current_request] = nil
end

.currentObject



16
17
18
# File 'lib/inner_performance/current_request.rb', line 16

def current
  CurrentRequest.init
end

.initObject



12
13
14
# File 'lib/inner_performance/current_request.rb', line 12

def init
  Thread.current[:ip_current_request] ||= CurrentRequest.new(SecureRandom.hex(16))
end

Instance Method Details

#trace(options = {}) ⇒ Object



33
34
35
# File 'lib/inner_performance/current_request.rb', line 33

def trace(options = {})
  @traces << options.merge(time: Time.current)
end