-
-
Notifications
You must be signed in to change notification settings - Fork 1.5k
/
ghttp_server_log.go
93 lines (87 loc) · 2.72 KB
/
ghttp_server_log.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
// Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
//
// This Source Code Form is subject to the terms of the MIT License.
// If a copy of the MIT was not distributed with this file,
// You can obtain one at https://github.com/gogf/gf.
package ghttp
import (
"fmt"
"github.com/gogf/gf/v2/errors/gerror"
"github.com/gogf/gf/v2/internal/instance"
"github.com/gogf/gf/v2/os/glog"
"github.com/gogf/gf/v2/text/gstr"
)
// handleAccessLog handles the access logging for server.
func (s *Server) handleAccessLog(r *Request) {
if !s.IsAccessLogEnabled() {
return
}
var (
scheme = "http"
proto = r.Header.Get("X-Forwarded-Proto")
loggerInstanceKey = fmt.Sprintf(`Acccess Logger Of Server:%s`, s.instance)
)
if r.TLS != nil || gstr.Equal(proto, "https") {
scheme = "https"
}
content := fmt.Sprintf(
`%d "%s %s %s %s %s" %.3f, %s, "%s", "%s"`,
r.Response.Status, r.Method, scheme, r.Host, r.URL.String(), r.Proto,
float64(r.LeaveTime-r.EnterTime)/1000,
r.GetClientIp(), r.Referer(), r.UserAgent(),
)
logger := instance.GetOrSetFuncLock(loggerInstanceKey, func() interface{} {
l := s.Logger().Clone()
l.SetFile(s.config.AccessLogPattern)
l.SetStdoutPrint(s.config.LogStdout)
l.SetLevelPrint(false)
return l
}).(*glog.Logger)
logger.Printf(r.Context(), content)
}
// handleErrorLog handles the error logging for server.
func (s *Server) handleErrorLog(err error, r *Request) {
// It does nothing if error logging is custom disabled.
if !s.IsErrorLogEnabled() {
return
}
var (
code = gerror.Code(err)
scheme = "http"
codeDetail = code.Detail()
proto = r.Header.Get("X-Forwarded-Proto")
loggerInstanceKey = fmt.Sprintf(`Error Logger Of Server:%s`, s.instance)
codeDetailStr string
)
if r.TLS != nil || gstr.Equal(proto, "https") {
scheme = "https"
}
if codeDetail != nil {
codeDetailStr = gstr.Replace(fmt.Sprintf(`%+v`, codeDetail), "\n", " ")
}
content := fmt.Sprintf(
`%d "%s %s %s %s %s" %.3f, %s, "%s", "%s", %d, "%s", "%+v"`,
r.Response.Status, r.Method, scheme, r.Host, r.URL.String(), r.Proto,
float64(r.LeaveTime-r.EnterTime)/1000,
r.GetClientIp(), r.Referer(), r.UserAgent(),
code.Code(), code.Message(), codeDetailStr,
)
if s.config.ErrorStack {
if stack := gerror.Stack(err); stack != "" {
content += "\nStack:\n" + stack
} else {
content += ", " + err.Error()
}
} else {
content += ", " + err.Error()
}
logger := instance.GetOrSetFuncLock(loggerInstanceKey, func() interface{} {
l := s.Logger().Clone()
l.SetStack(false)
l.SetFile(s.config.ErrorLogPattern)
l.SetStdoutPrint(s.config.LogStdout)
l.SetLevelPrint(false)
return l
}).(*glog.Logger)
logger.Error(r.Context(), content)
}