Files
Atay-Makhzan/modules/web/routing/logger.go
T

127 lines
4.2 KiB
Go
Raw Normal View History

2022-01-20 19:41:25 +08:00
// Copyright 2021 The Gitea Authors. All rights reserved.
// SPDX-License-Identifier: MIT
2022-01-20 19:41:25 +08:00
package routing
import (
"net/http"
2023-05-22 06:35:11 +08:00
"strings"
2022-01-20 19:41:25 +08:00
"time"
"code.gitea.io/gitea/modules/log"
"code.gitea.io/gitea/modules/web/types"
2022-01-20 19:41:25 +08:00
)
// NewLoggerHandler is a handler that will log routing to the router log taking account of
// routing information
func NewLoggerHandler() func(next http.Handler) http.Handler {
manager := requestRecordsManager{
requestRecords: map[uint64]*requestRecord{},
}
manager.startSlowQueryDetector(3 * time.Second)
logger := log.GetLogger("router")
manager.print = logPrinter(logger)
return manager.handler
}
var (
2023-05-22 06:35:11 +08:00
startMessage = log.NewColoredValue("started ", log.DEBUG.ColorAttributes()...)
slowMessage = log.NewColoredValue("slow ", log.WARN.ColorAttributes()...)
pollingMessage = log.NewColoredValue("polling ", log.INFO.ColorAttributes()...)
failedMessage = log.NewColoredValue("failed ", log.WARN.ColorAttributes()...)
completedMessage = log.NewColoredValue("completed", log.INFO.ColorAttributes()...)
unknownHandlerMessage = log.NewColoredValue("completed", log.ERROR.ColorAttributes()...)
2022-01-20 19:41:25 +08:00
)
func logPrinter(logger log.Logger) func(trigger Event, record *requestRecord) {
2025-03-08 21:47:11 +08:00
const callerName = "HTTPRequest"
logTrace := func(fmt string, args ...any) {
logger.Log(2, &log.Event{Level: log.TRACE, Caller: callerName}, fmt, args...)
}
logInfo := func(fmt string, args ...any) {
logger.Log(2, &log.Event{Level: log.INFO, Caller: callerName}, fmt, args...)
}
logWarn := func(fmt string, args ...any) {
logger.Log(2, &log.Event{Level: log.WARN, Caller: callerName}, fmt, args...)
}
logError := func(fmt string, args ...any) {
logger.Log(2, &log.Event{Level: log.ERROR, Caller: callerName}, fmt, args...)
}
2022-01-20 19:41:25 +08:00
return func(trigger Event, record *requestRecord) {
if trigger == StartEvent {
2023-05-22 06:35:11 +08:00
if !logger.LevelEnabled(log.TRACE) {
2022-01-20 19:41:25 +08:00
// for performance, if the "started" message shouldn't be logged, we just return as early as possible
// developers can set the router log level to TRACE to get the "started" request messages.
return
}
// when a request starts, we have no information about the handler function information, we only have the request path
req := record.request
2025-03-08 21:47:11 +08:00
logTrace("router: %s %v %s for %s", startMessage, log.ColoredMethod(req.Method), req.RequestURI, req.RemoteAddr)
2022-01-20 19:41:25 +08:00
return
}
req := record.request
// Get data from the record
record.lock.Lock()
handlerFuncInfo := record.funcInfo.String()
isLongPolling := record.isLongPolling
isUnknownHandler := record.funcInfo == nil
panicErr := record.panicError
record.lock.Unlock()
if trigger == StillExecutingEvent {
message := slowMessage
2025-03-08 21:47:11 +08:00
logf := logWarn
2022-01-20 19:41:25 +08:00
if isLongPolling {
2025-03-08 21:47:11 +08:00
logf = logInfo
2022-01-20 19:41:25 +08:00
message = pollingMessage
}
2023-05-22 06:35:11 +08:00
logf("router: %s %v %s for %s, elapsed %v @ %s",
2022-01-20 19:41:25 +08:00
message,
log.ColoredMethod(req.Method), req.RequestURI, req.RemoteAddr,
log.ColoredTime(time.Since(record.startTime)),
handlerFuncInfo,
)
return
}
if panicErr != nil {
2025-03-08 21:47:11 +08:00
logWarn("router: %s %v %s for %s, panic in %v @ %s, err=%v",
2022-01-20 19:41:25 +08:00
failedMessage,
log.ColoredMethod(req.Method), req.RequestURI, req.RemoteAddr,
log.ColoredTime(time.Since(record.startTime)),
handlerFuncInfo,
panicErr,
)
return
}
var status int
if v, ok := record.responseWriter.(types.ResponseStatusProvider); ok {
status = v.WrittenStatus()
2022-01-20 19:41:25 +08:00
}
2025-03-08 21:47:11 +08:00
logf := logInfo
2025-06-02 23:22:43 +08:00
// lower the log level for some specific requests, in most cases these logs are not useful
2025-10-19 00:37:50 +08:00
if status > 0 && status < 400 &&
strings.HasPrefix(req.RequestURI, "/assets/") /* static assets */ ||
2025-06-02 23:22:43 +08:00
req.RequestURI == "/user/events" /* Server-Sent Events (SSE) handler */ ||
req.RequestURI == "/api/actions/runner.v1.RunnerService/FetchTask" /* Actions Runner polling */ {
2025-03-08 21:47:11 +08:00
logf = logTrace
2023-05-22 06:35:11 +08:00
}
2022-01-20 19:41:25 +08:00
message := completedMessage
if isUnknownHandler {
2025-03-08 21:47:11 +08:00
logf = logError
2022-01-20 19:41:25 +08:00
message = unknownHandlerMessage
}
2023-05-22 06:35:11 +08:00
logf("router: %s %v %s for %s, %v %v in %v @ %s",
2022-01-20 19:41:25 +08:00
message,
log.ColoredMethod(req.Method), req.RequestURI, req.RemoteAddr,
log.ColoredStatus(status), log.ColoredStatus(status, http.StatusText(status)), log.ColoredTime(time.Since(record.startTime)),
handlerFuncInfo,
)
}
}