fix middleware/logging unable to print params (#868)

fix middleware/logging unable to print params
pull/873/head
包子 4 years ago committed by GitHub
parent 4f1d2f056f
commit b03c810dce
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 78
      middleware/logging/logging.go

@ -19,28 +19,32 @@ func Server(l log.Logger) middleware.Middleware {
var ( var (
path string path string
method string method string
params string args string
component string component string
query string
) )
if info, ok := http.FromServerContext(ctx); ok { if info, ok := http.FromServerContext(ctx); ok {
component = "HTTP" component = "HTTP"
path = info.Request.RequestURI path = info.Request.URL.Path
method = info.Request.Method method = info.Request.Method
params = info.Request.Form.Encode() args = req.(fmt.Stringer).String()
query = info.Request.URL.RawQuery
} else if info, ok := grpc.FromServerContext(ctx); ok { } else if info, ok := grpc.FromServerContext(ctx); ok {
component = "gRPC" component = "gRPC"
path = info.FullMethod path = info.FullMethod
method = "POST" method = "POST"
params = req.(fmt.Stringer).String() args = req.(fmt.Stringer).String()
} }
reply, err := handler(ctx, req) reply, err := handler(ctx, req)
if component == "HTTP" {
if err != nil { if err != nil {
logger.Errorw( logger.Errorw(
"kind", "server", "kind", "server",
"component", component, "component", component,
"path", path, "path", path,
"method", method, "method", method,
"params", params, "args", args,
"query", query,
"code", errors.Code(err), "code", errors.Code(err),
"error", err.Error(), "error", err.Error(),
) )
@ -51,9 +55,32 @@ func Server(l log.Logger) middleware.Middleware {
"component", component, "component", component,
"path", path, "path", path,
"method", method, "method", method,
"params", params, "args", args,
"query", query,
"code", 0, "code", 0,
) )
} else {
if err != nil {
logger.Errorw(
"kind", "server",
"component", component,
"path", path,
"method", method,
"args", args,
"code", errors.Code(err),
"error", err.Error(),
)
return nil, err
}
logger.Infow(
"kind", "server",
"component", component,
"path", path,
"method", method,
"args", args,
"code", 0,
)
}
return reply, nil return reply, nil
} }
} }
@ -67,28 +94,32 @@ func Client(l log.Logger) middleware.Middleware {
var ( var (
path string path string
method string method string
params string
component string component string
args string
query string
) )
if info, ok := http.FromClientContext(ctx); ok { if info, ok := http.FromClientContext(ctx); ok {
component = "HTTP" component = "HTTP"
path = info.Request.RequestURI path = info.Request.URL.Path
method = info.Request.Method method = info.Request.Method
params = info.Request.Form.Encode() args = req.(fmt.Stringer).String()
query = info.Request.URL.RawQuery
} else if info, ok := grpc.FromClientContext(ctx); ok { } else if info, ok := grpc.FromClientContext(ctx); ok {
path = info.FullMethod path = info.FullMethod
method = "POST" method = "POST"
component = "gRPC" component = "gRPC"
params = req.(fmt.Stringer).String() args = req.(fmt.Stringer).String()
} }
reply, err := handler(ctx, req) reply, err := handler(ctx, req)
if component == "HTTP" {
if err != nil { if err != nil {
logger.Errorw( logger.Errorw(
"kind", "client", "kind", "client",
"component", component, "component", component,
"path", path, "path", path,
"method", method, "method", method,
"params", params, "args", args,
"query", query,
"code", errors.Code(err), "code", errors.Code(err),
"error", err.Error(), "error", err.Error(),
) )
@ -99,9 +130,32 @@ func Client(l log.Logger) middleware.Middleware {
"component", component, "component", component,
"path", path, "path", path,
"method", method, "method", method,
"params", params, "args", args,
"query", query,
"code", 0, "code", 0,
) )
} else {
if err != nil {
logger.Errorw(
"kind", "client",
"component", component,
"path", path,
"method", method,
"args", args,
"code", errors.Code(err),
"error", err.Error(),
)
return nil, err
}
logger.Infow(
"kind", "client",
"component", component,
"path", path,
"method", method,
"args", args,
"code", 0,
)
}
return reply, nil return reply, nil
} }
} }

Loading…
Cancel
Save