From b03c810dce8b2b2ed4c3659dd8d1d46f3e39efb4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=8C=85=E5=AD=90?= Date: Tue, 27 Apr 2021 15:44:35 +0800 Subject: [PATCH] fix middleware/logging unable to print params (#868) fix middleware/logging unable to print params --- middleware/logging/logging.go | 126 ++++++++++++++++++++++++---------- 1 file changed, 90 insertions(+), 36 deletions(-) diff --git a/middleware/logging/logging.go b/middleware/logging/logging.go index 5bab4fe1a..0449ec614 100644 --- a/middleware/logging/logging.go +++ b/middleware/logging/logging.go @@ -19,41 +19,68 @@ func Server(l log.Logger) middleware.Middleware { var ( path string method string - params string + args string component string + query string ) if info, ok := http.FromServerContext(ctx); ok { component = "HTTP" - path = info.Request.RequestURI + path = info.Request.URL.Path 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 { component = "gRPC" path = info.FullMethod method = "POST" - params = req.(fmt.Stringer).String() + args = req.(fmt.Stringer).String() } reply, err := handler(ctx, req) - if err != nil { - logger.Errorw( + if component == "HTTP" { + if err != nil { + logger.Errorw( + "kind", "server", + "component", component, + "path", path, + "method", method, + "args", args, + "query", query, + "code", errors.Code(err), + "error", err.Error(), + ) + return nil, err + } + logger.Infow( "kind", "server", "component", component, "path", path, "method", method, - "params", params, - "code", errors.Code(err), - "error", err.Error(), + "args", args, + "query", query, + "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 nil, err } - logger.Infow( - "kind", "server", - "component", component, - "path", path, - "method", method, - "params", params, - "code", 0, - ) return reply, nil } } @@ -67,41 +94,68 @@ func Client(l log.Logger) middleware.Middleware { var ( path string method string - params string component string + args string + query string ) if info, ok := http.FromClientContext(ctx); ok { component = "HTTP" - path = info.Request.RequestURI + path = info.Request.URL.Path 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 { path = info.FullMethod method = "POST" component = "gRPC" - params = req.(fmt.Stringer).String() + args = req.(fmt.Stringer).String() } reply, err := handler(ctx, req) - if err != nil { - logger.Errorw( + if component == "HTTP" { + if err != nil { + logger.Errorw( + "kind", "client", + "component", component, + "path", path, + "method", method, + "args", args, + "query", query, + "code", errors.Code(err), + "error", err.Error(), + ) + return nil, err + } + logger.Infow( "kind", "client", "component", component, "path", path, "method", method, - "params", params, - "code", errors.Code(err), - "error", err.Error(), + "args", args, + "query", query, + "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 nil, err } - logger.Infow( - "kind", "client", - "component", component, - "path", path, - "method", method, - "params", params, - "code", 0, - ) return reply, nil } }