Class: OpticsAgent::RackMiddleware
- Inherits:
-
Object
- Object
- OpticsAgent::RackMiddleware
- Defined in:
- lib/optics-agent/rack-middleware.rb
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize(app, options = {}) ⇒ RackMiddleware
constructor
A new instance of RackMiddleware.
Constructor Details
#initialize(app, options = {}) ⇒ RackMiddleware
Returns a new instance of RackMiddleware.
6 7 8 |
# File 'lib/optics-agent/rack-middleware.rb', line 6 def initialize(app, ={}) @app = app end |
Instance Method Details
#call(env) ⇒ Object
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
# File 'lib/optics-agent/rack-middleware.rb', line 10 def call(env) start_time = Time.now # XXX: figure out a way to pass this in here agent = OpticsAgent::Agent.instance agent.debug { "rack-middleware: request started" } query = OpticsAgent::Reporting::Query.new # Attach so resolver middleware can access env[:optics_agent] = RackAgent.new(agent, query) result = @app.call(env) # XXX: this approach means if the user forgets to call with_document # we just never log queries. Can we detect if the request is a graphql one? agent.debug { "rack-middleware: request finished" } if (query.document) agent.debug { "rack-middleware: adding query to agent" } agent.add_query(query, env, start_time, Time.now) end result end |