Module: Pliny::Extensions::Instruments

Defined in:
lib/pliny/extensions/instruments.rb

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.registered(app) ⇒ Object



3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# File 'lib/pliny/extensions/instruments.rb', line 3

def self.registered(app)
  app.before do
    @request_start = Time.now
    Pliny.log(
      instrumentation: true,
      at:              "start",
      method:          request.request_method,
      path:            request.path_info,
    )
  end

  app.after do
    Pliny.log(
      instrumentation: true,
      at:              "finish",
      method:          request.request_method,
      path:            request.path_info,
      route_signature: route_signature,
      status:          status,
      elapsed:         (Time.now - @request_start).to_f
    )
  end

  app.helpers do
    def route_signature
      env["ROUTE_SIGNATURE"]
    end
  end
end

Instance Method Details

#route(verb, path) ⇒ Object



33
34
35
36
# File 'lib/pliny/extensions/instruments.rb', line 33

def route(verb, path, *)
  condition { env["ROUTE_SIGNATURE"] = path.to_s }
  super
end