Class: StackProf::Middleware

Inherits:
Object
  • Object
show all
Defined in:
lib/stackprof/middleware.rb

Class Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(app, options = {}) ⇒ Middleware

Returns a new instance of Middleware.



5
6
7
8
9
10
11
12
13
14
15
# File 'lib/stackprof/middleware.rb', line 5

def initialize(app, options = {})
  @app       = app
  @options   = options
  @num_reqs  = options[:save_every] || nil

  Middleware.mode     = options[:mode] || :cpu
  Middleware.interval = options[:interval] || 1000
  Middleware.enabled  = options[:enabled]
  Middleware.path     = options[:path] || 'tmp'
  at_exit{ Middleware.save } if options[:save_at_exit]
end

Class Attribute Details

.enabledObject

Returns the value of attribute enabled.



32
33
34
# File 'lib/stackprof/middleware.rb', line 32

def enabled
  @enabled
end

.intervalObject

Returns the value of attribute interval.



32
33
34
# File 'lib/stackprof/middleware.rb', line 32

def interval
  @interval
end

.modeObject

Returns the value of attribute mode.



32
33
34
# File 'lib/stackprof/middleware.rb', line 32

def mode
  @mode
end

.pathObject

Returns the value of attribute path.



32
33
34
# File 'lib/stackprof/middleware.rb', line 32

def path
  @path
end

Class Method Details

.enabled?(env) ⇒ Boolean

Returns:

  • (Boolean)


34
35
36
37
38
39
40
# File 'lib/stackprof/middleware.rb', line 34

def enabled?(env)
  if enabled.respond_to?(:call)
    enabled.call(env)
  else
    enabled
  end
end

.save(filename = nil) ⇒ Object



42
43
44
45
46
47
48
49
50
51
# File 'lib/stackprof/middleware.rb', line 42

def save(filename = nil)
  if results = StackProf.results
    FileUtils.mkdir_p(Middleware.path)
    filename ||= "stackprof-#{results[:mode]}-#{Process.pid}-#{Time.now.to_i}.dump"
    File.open(File.join(Middleware.path, filename), 'wb') do |f|
      f.write Marshal.dump(results)
    end
    filename
  end
end

Instance Method Details

#call(env) ⇒ Object



17
18
19
20
21
22
23
24
25
26
27
28
29
# File 'lib/stackprof/middleware.rb', line 17

def call(env)
  enabled = Middleware.enabled?(env)
  StackProf.start(mode: Middleware.mode, interval: Middleware.interval) if enabled
  @app.call(env)
ensure
  if enabled
    StackProf.stop
    if @num_reqs && (@num_reqs-=1) == 0
      @num_reqs = @options[:save_every]
      Middleware.save
    end
  end
end