Class: Rack::Logstash

Inherits:
Object
  • Object
show all
Defined in:
lib/rack/logstash.rb,
lib/rack/logstash/transport.rb

Defined Under Namespace

Classes: Transport

Instance Method Summary collapse

Constructor Details

#initialize(app, url, opts = {}) ⇒ Logstash

Returns a new instance of Logstash.



8
9
10
11
12
# File 'lib/rack/logstash.rb', line 8

def initialize(app, url, opts = {})
	@app    = app
	@server = Rack::Logstash::Transport.new(url)
	@tags   = opts.fetch(:tags, [])
end

Instance Method Details

#call(env) ⇒ Object



14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
# File 'lib/rack/logstash.rb', line 14

def call(env)
	env['rack.logstash.start_time'] = Time.now

	begin
		@app.call(env).tap do |response|
			begin
				log_request(env, response)
			rescue StandardError => ex
				$stderr.puts "Failed to log request: #{ex.message} (#{ex.class})"
				$stderr.puts ex.backtrace.map { |l| "  #{l}" }
			end
		end
	rescue StandardError => ex
		log_exception(env, ex)
		raise
	end
end