Tracing statusCodeTracker need to implement CloseNotify

This commit is contained in:
Michael 2018-01-25 16:34:02 +01:00 committed by Traefiker
parent 9f741abd84
commit b50aebd2ed
4 changed files with 63 additions and 16 deletions

View file

@ -32,11 +32,11 @@ func (e *entryPointMiddleware) ServeHTTP(w http.ResponseWriter, r *http.Request,
LogRequest(span, r) LogRequest(span, r)
ext.SpanKindRPCServer.Set(span) ext.SpanKindRPCServer.Set(span)
w = &statusCodeTracker{w, 200}
r = r.WithContext(opentracing.ContextWithSpan(r.Context(), span)) r = r.WithContext(opentracing.ContextWithSpan(r.Context(), span))
next(w, r) recorder := newStatusCodeRecoder(w, 200)
next(recorder, r)
LogResponseCode(span, w.(*statusCodeTracker).status) LogResponseCode(span, recorder.Status())
span.Finish() span.Finish()
} }

View file

@ -38,9 +38,9 @@ func (f *forwarderMiddleware) ServeHTTP(w http.ResponseWriter, r *http.Request,
InjectRequestHeaders(r) InjectRequestHeaders(r)
w = &statusCodeTracker{w, 200} recorder := newStatusCodeRecoder(w, 200)
next(w, r) next(recorder, r)
LogResponseCode(span, w.(*statusCodeTracker).status) LogResponseCode(span, recorder.Status())
} }

View file

@ -0,0 +1,57 @@
package tracing
import (
"bufio"
"net"
"net/http"
)
type statusCodeRecoder interface {
http.ResponseWriter
Status() int
}
type statusCodeWithoutCloseNotify struct {
http.ResponseWriter
status int
}
// WriteHeader captures the status code for later retrieval.
func (s *statusCodeWithoutCloseNotify) WriteHeader(status int) {
s.status = status
s.ResponseWriter.WriteHeader(status)
}
// Status get response status
func (s *statusCodeWithoutCloseNotify) Status() int {
return s.status
}
// Hijack hijacks the connection
func (s *statusCodeWithoutCloseNotify) Hijack() (net.Conn, *bufio.ReadWriter, error) {
return s.ResponseWriter.(http.Hijacker).Hijack()
}
// Flush sends any buffered data to the client.
func (s *statusCodeWithoutCloseNotify) Flush() {
if flusher, ok := s.ResponseWriter.(http.Flusher); ok {
flusher.Flush()
}
}
type statusCodeWithCloseNotify struct {
*statusCodeWithoutCloseNotify
}
func (s *statusCodeWithCloseNotify) CloseNotify() <-chan bool {
return s.ResponseWriter.(http.CloseNotifier).CloseNotify()
}
// newStatusCodeRecoder returns an initialized statusCodeRecoder.
func newStatusCodeRecoder(rw http.ResponseWriter, status int) statusCodeRecoder {
recorder := &statusCodeWithoutCloseNotify{rw, status}
if _, ok := rw.(http.CloseNotifier); ok {
return &statusCodeWithCloseNotify{recorder}
}
return recorder
}

View file

@ -28,16 +28,6 @@ type Backend interface {
Setup(serviceName string) (opentracing.Tracer, io.Closer, error) Setup(serviceName string) (opentracing.Tracer, io.Closer, error)
} }
type statusCodeTracker struct {
http.ResponseWriter
status int
}
func (s *statusCodeTracker) WriteHeader(status int) {
s.status = status
s.ResponseWriter.WriteHeader(status)
}
// Setup Tracing middleware // Setup Tracing middleware
func (t *Tracing) Setup() { func (t *Tracing) Setup() {
var err error var err error