2018-01-10 17:48:04 +01:00
|
|
|
package tracing
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"github.com/containous/traefik/log"
|
|
|
|
"github.com/opentracing/opentracing-go/ext"
|
|
|
|
"github.com/urfave/negroni"
|
|
|
|
)
|
|
|
|
|
|
|
|
type forwarderMiddleware struct {
|
|
|
|
frontend string
|
|
|
|
backend string
|
|
|
|
opName string
|
|
|
|
*Tracing
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewForwarderMiddleware creates a new forwarder middleware that traces the outgoing request
|
|
|
|
func (t *Tracing) NewForwarderMiddleware(frontend, backend string) negroni.Handler {
|
|
|
|
log.Debugf("Added outgoing tracing middleware %s", frontend)
|
|
|
|
return &forwarderMiddleware{
|
|
|
|
Tracing: t,
|
|
|
|
frontend: frontend,
|
|
|
|
backend: backend,
|
|
|
|
opName: fmt.Sprintf("forward %s/%s", frontend, backend),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *forwarderMiddleware) ServeHTTP(w http.ResponseWriter, r *http.Request, next http.HandlerFunc) {
|
|
|
|
span, r, finish := StartSpan(r, f.opName, true)
|
|
|
|
defer finish()
|
|
|
|
span.SetTag("frontend.name", f.frontend)
|
|
|
|
span.SetTag("backend.name", f.backend)
|
|
|
|
ext.HTTPMethod.Set(span, r.Method)
|
2018-05-08 12:00:03 +02:00
|
|
|
ext.HTTPUrl.Set(span, fmt.Sprintf("%s%s", r.URL.String(), r.RequestURI))
|
2018-01-10 17:48:04 +01:00
|
|
|
span.SetTag("http.host", r.Host)
|
|
|
|
|
|
|
|
InjectRequestHeaders(r)
|
|
|
|
|
2018-01-25 16:34:02 +01:00
|
|
|
recorder := newStatusCodeRecoder(w, 200)
|
2018-01-10 17:48:04 +01:00
|
|
|
|
2018-01-25 16:34:02 +01:00
|
|
|
next(recorder, r)
|
2018-01-10 17:48:04 +01:00
|
|
|
|
2018-01-25 16:34:02 +01:00
|
|
|
LogResponseCode(span, recorder.Status())
|
2018-01-10 17:48:04 +01:00
|
|
|
}
|