|  | 
|  | 1 | +package http | 
|  | 2 | + | 
|  | 3 | +import ( | 
|  | 4 | +	"bufio" | 
|  | 5 | +	"net" | 
|  | 6 | +	"net/http" | 
|  | 7 | +	"time" | 
|  | 8 | + | 
|  | 9 | +	"k8s.io/klog/v2" | 
|  | 10 | +) | 
|  | 11 | + | 
|  | 12 | +func RequestMiddleware(next http.Handler) http.Handler { | 
|  | 13 | +	return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { | 
|  | 14 | +		start := time.Now() | 
|  | 15 | + | 
|  | 16 | +		lrw := &loggingResponseWriter{ | 
|  | 17 | +			ResponseWriter: w, | 
|  | 18 | +			statusCode:     http.StatusOK, | 
|  | 19 | +		} | 
|  | 20 | + | 
|  | 21 | +		next.ServeHTTP(lrw, r) | 
|  | 22 | + | 
|  | 23 | +		duration := time.Since(start) | 
|  | 24 | +		klog.V(5).Infof("%s %s %d %v", r.Method, r.URL.Path, lrw.statusCode, duration) | 
|  | 25 | +	}) | 
|  | 26 | +} | 
|  | 27 | + | 
|  | 28 | +type loggingResponseWriter struct { | 
|  | 29 | +	http.ResponseWriter | 
|  | 30 | +	statusCode    int | 
|  | 31 | +	headerWritten bool | 
|  | 32 | +} | 
|  | 33 | + | 
|  | 34 | +func (lrw *loggingResponseWriter) WriteHeader(code int) { | 
|  | 35 | +	if !lrw.headerWritten { | 
|  | 36 | +		lrw.statusCode = code | 
|  | 37 | +		lrw.headerWritten = true | 
|  | 38 | +		lrw.ResponseWriter.WriteHeader(code) | 
|  | 39 | +	} | 
|  | 40 | +} | 
|  | 41 | + | 
|  | 42 | +func (lrw *loggingResponseWriter) Write(b []byte) (int, error) { | 
|  | 43 | +	if !lrw.headerWritten { | 
|  | 44 | +		lrw.statusCode = http.StatusOK | 
|  | 45 | +		lrw.headerWritten = true | 
|  | 46 | +	} | 
|  | 47 | +	return lrw.ResponseWriter.Write(b) | 
|  | 48 | +} | 
|  | 49 | + | 
|  | 50 | +func (lrw *loggingResponseWriter) Flush() { | 
|  | 51 | +	if flusher, ok := lrw.ResponseWriter.(http.Flusher); ok { | 
|  | 52 | +		flusher.Flush() | 
|  | 53 | +	} | 
|  | 54 | +} | 
|  | 55 | + | 
|  | 56 | +func (lrw *loggingResponseWriter) Hijack() (net.Conn, *bufio.ReadWriter, error) { | 
|  | 57 | +	if hijacker, ok := lrw.ResponseWriter.(http.Hijacker); ok { | 
|  | 58 | +		return hijacker.Hijack() | 
|  | 59 | +	} | 
|  | 60 | +	return nil, nil, http.ErrNotSupported | 
|  | 61 | +} | 
0 commit comments