refactor(rest): keep rest log collector context key private (#3407)

This commit is contained in:
cong
2023-07-10 09:52:26 +08:00
committed by GitHub
parent b71453985c
commit 61e562d0c7
4 changed files with 39 additions and 23 deletions

View File

@@ -2,6 +2,7 @@ package internal
import (
"bytes"
"context"
"fmt"
"net/http"
"sync"
@@ -10,13 +11,32 @@ import (
"github.com/zeromicro/go-zero/rest/httpx"
)
// LogContext is a context key.
var LogContext = contextKey("request_logs")
// logContextKey is a context key.
var logContextKey = contextKey("request_logs")
// A LogCollector is used to collect logs.
type LogCollector struct {
Messages []string
lock sync.Mutex
type (
// LogCollector is used to collect logs.
LogCollector struct {
Messages []string
lock sync.Mutex
}
contextKey string
)
// WithLogCollector returns a new context with LogCollector.
func WithLogCollector(ctx context.Context, lc *LogCollector) context.Context {
return context.WithValue(ctx, logContextKey, lc)
}
// LogCollectorFromContext returns LogCollector from ctx.
func LogCollectorFromContext(ctx context.Context) *LogCollector {
val := ctx.Value(logContextKey)
if val == nil {
return nil
}
return val.(*LogCollector)
}
// Append appends msg into log context.
@@ -73,9 +93,9 @@ func Infof(r *http.Request, format string, v ...any) {
}
func appendLog(r *http.Request, message string) {
logs := r.Context().Value(LogContext)
logs := LogCollectorFromContext(r.Context())
if logs != nil {
logs.(*LogCollector).Append(message)
logs.Append(message)
}
}
@@ -90,9 +110,3 @@ func formatf(r *http.Request, format string, v ...any) string {
func formatWithReq(r *http.Request, v string) string {
return fmt.Sprintf("(%s - %s) %s", r.RequestURI, httpx.GetRemoteAddr(r), v)
}
type contextKey string
func (c contextKey) String() string {
return "rest/internal context key " + string(c)
}