mediamtx/internal/httpserv/middleware_logger.go

56 lines
1.4 KiB
Go
Raw Normal View History

package httpserv
2022-12-15 23:50:47 +00:00
import (
"bytes"
"fmt"
"net/http"
"net/http/httputil"
"github.com/gin-gonic/gin"
2023-05-16 14:14:20 +00:00
"github.com/bluenviron/mediamtx/internal/logger"
2022-12-15 23:50:47 +00:00
)
type loggerWriter struct {
2022-12-15 23:50:47 +00:00
gin.ResponseWriter
buf bytes.Buffer
}
func (w *loggerWriter) Write(b []byte) (int, error) {
2022-12-15 23:50:47 +00:00
w.buf.Write(b)
return w.ResponseWriter.Write(b)
}
func (w *loggerWriter) WriteString(s string) (int, error) {
2022-12-15 23:50:47 +00:00
w.buf.WriteString(s)
return w.ResponseWriter.WriteString(s)
}
func (w *loggerWriter) dump() string {
2022-12-15 23:50:47 +00:00
var buf bytes.Buffer
fmt.Fprintf(&buf, "%s %d %s\n", "HTTP/1.1", w.ResponseWriter.Status(), http.StatusText(w.ResponseWriter.Status()))
w.ResponseWriter.Header().Write(&buf)
buf.Write([]byte("\n"))
if w.buf.Len() > 0 {
fmt.Fprintf(&buf, "(body of %d bytes)", w.buf.Len())
}
return buf.String()
}
// MiddlewareLogger is a middleware that logs requests and responses.
func MiddlewareLogger(p logger.Writer) func(*gin.Context) {
2022-12-15 23:50:47 +00:00
return func(ctx *gin.Context) {
p.Log(logger.Debug, "[conn %v] %s %s", ctx.Request.RemoteAddr, ctx.Request.Method, ctx.Request.URL.Path)
2022-12-15 23:50:47 +00:00
byts, _ := httputil.DumpRequest(ctx.Request, true)
p.Log(logger.Debug, "[conn %v] [c->s] %s", ctx.Request.RemoteAddr, string(byts))
2022-12-15 23:50:47 +00:00
logw := &loggerWriter{ResponseWriter: ctx.Writer}
2022-12-15 23:50:47 +00:00
ctx.Writer = logw
ctx.Next()
p.Log(logger.Debug, "[conn %v] [s->c] %s", ctx.Request.RemoteAddr, logw.dump())
2022-12-15 23:50:47 +00:00
}
}