go-zero/rest/internal/log.go

91 lines
1.8 KiB
Go
Raw Normal View History

2020-07-29 18:00:04 +08:00
package internal
2020-07-26 17:09:05 +08:00
import (
"bytes"
"fmt"
"net/http"
"sync"
2020-08-08 16:40:10 +08:00
"github.com/tal-tech/go-zero/core/logx"
2020-08-12 12:25:52 +08:00
"github.com/tal-tech/go-zero/rest/httpx"
2020-07-26 17:09:05 +08:00
)
var LogContext = contextKey("request_logs")
2020-07-26 17:09:05 +08:00
type LogCollector struct {
Messages []string
lock sync.Mutex
}
func (lc *LogCollector) Append(msg string) {
lc.lock.Lock()
lc.Messages = append(lc.Messages, msg)
lc.lock.Unlock()
}
func (lc *LogCollector) Flush() string {
var buffer bytes.Buffer
start := true
for _, message := range lc.takeAll() {
if start {
start = false
} else {
buffer.WriteByte('\n')
}
buffer.WriteString(message)
}
return buffer.String()
}
func (lc *LogCollector) takeAll() []string {
lc.lock.Lock()
messages := lc.Messages
lc.Messages = nil
lc.lock.Unlock()
return messages
}
func Error(r *http.Request, v ...interface{}) {
logx.ErrorCaller(1, format(r, v...))
}
func Errorf(r *http.Request, format string, v ...interface{}) {
logx.ErrorCaller(1, formatf(r, format, v...))
}
func Info(r *http.Request, v ...interface{}) {
appendLog(r, format(r, v...))
}
func Infof(r *http.Request, format string, v ...interface{}) {
appendLog(r, formatf(r, format, v...))
}
func appendLog(r *http.Request, message string) {
logs := r.Context().Value(LogContext)
if logs != nil {
logs.(*LogCollector).Append(message)
}
}
func format(r *http.Request, v ...interface{}) string {
return formatWithReq(r, fmt.Sprint(v...))
}
func formatf(r *http.Request, format string, v ...interface{}) string {
return formatWithReq(r, fmt.Sprintf(format, v...))
}
func formatWithReq(r *http.Request, v string) string {
2020-08-12 12:25:52 +08:00
return fmt.Sprintf("(%s - %s) %s", r.RequestURI, httpx.GetRemoteAddr(r), v)
2020-07-26 17:09:05 +08:00
}
type contextKey string
func (c contextKey) String() string {
return "rest/internal context key " + string(c)
}