Class: ExisRay::HttpMiddleware

Inherits:
Object
  • Object
show all
Defined in:
lib/exis_ray/http_middleware.rb

Overview

Rack middleware que hidrata el Tracer con el header de trazabilidad entrante. Se inserta automáticamente después de ‘ActionDispatch::RequestId` via Railtie.

Instance Method Summary collapse

Constructor Details

#initialize(app) ⇒ HttpMiddleware

Returns a new instance of HttpMiddleware.



7
8
9
# File 'lib/exis_ray/http_middleware.rb', line 7

def initialize(app)
  @app = app
end

Instance Method Details

#call(env) ⇒ Object



11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
# File 'lib/exis_ray/http_middleware.rb', line 11

def call(env)
  ExisRay::Tracer.hydrate(
    trace_id: env[ExisRay.configuration.trace_header],
    source: "http"
  )
  # Si la request no trae trace header entrante (servicio que es punto de
  # entrada, no eslabón intermedio de un trace distribuido), generamos un
  # root_id fresco igual que el resto de entrypoints
  # (Sidekiq::ServerMiddleware, BugBunny::ConsumerTracingMiddleware,
  # TaskMonitor). Sin esto root_id queda nil y JsonFormatter dropea todo
  # el bloque de tracer, incluido `source` (campo mandatorio). Ver issue #9.
  ExisRay::Tracer.root_id ||= ExisRay::Tracer.send(:generate_new_root)
  ExisRay::Tracer.request_id = env["action_dispatch.request_id"]
  ExisRay.sync_correlation_id

  @app.call(env)
rescue StandardError
  @app.call(env)
end