func logEndOfRequest(ctx context.Context, duration time.Duration, mw mutil.WriterProxy) { log.Ctx(ctx).WithFields(log.F{ "status": mw.Status(), "bytes": mw.BytesWritten(), "duration": duration, }).Info("Finished request") }
func (l *Logger) printResponse(w mutil.WriterProxy, delta time.Duration) { var buf bytes.Buffer buf.WriteString("Returning HTTP ") status := w.Status() if status < 200 { colorWrite(&buf, bBlue, "%03d", status) } else if status < 300 { colorWrite(&buf, bGreen, "%03d", status) } else if status < 400 { colorWrite(&buf, bCyan, "%03d", status) } else if status < 500 { colorWrite(&buf, bYellow, "%03d", status) } else { colorWrite(&buf, bRed, "%03d", status) } buf.WriteString(" in ") if delta < FastResponse { colorWrite(&buf, nGreen, "%s", delta.String()) } else if delta < AcceptableResponse { colorWrite(&buf, nYellow, "%s", delta.String()) } else { colorWrite(&buf, nRed, "%s", delta.String()) } log.Print(buf.String()) }
func printEnd(reqID string, w mutil.WriterProxy, dt time.Duration) { var buf bytes.Buffer if reqID != "" { cW(&buf, bBlack, "[%s] ", reqID) } buf.WriteString("Returning ") status := w.Status() if status < 200 { cW(&buf, bBlue, "%03d", status) } else if status < 300 { cW(&buf, bGreen, "%03d", status) } else if status < 400 { cW(&buf, bCyan, "%03d", status) } else if status < 500 { cW(&buf, bYellow, "%03d", status) } else { cW(&buf, bRed, "%03d", status) } buf.WriteString(" in ") if dt < 500*time.Millisecond { cW(&buf, nGreen, "%s", dt) } else if dt < 5*time.Second { cW(&buf, nYellow, "%s", dt) } else { cW(&buf, nRed, "%s", dt) } logs.Debug(buf.String()) }
func logEndOfRequest(ctx context.Context, duration time.Duration, mw mutil.WriterProxy) { fields := logrus.Fields{ "status": mw.Status(), "bytes": mw.BytesWritten(), "duration": duration, } log.WithFields(ctx, fields).Info("Finished request") }