/
user-logger.go
90 lines (84 loc) · 2.85 KB
/
user-logger.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
// GENERATED BY 'T'ransport 'G'enerator. DO NOT EDIT.
package transport
import (
"context"
"github.com/rs/zerolog"
"github.com/rs/zerolog/log"
"github.com/seniorGolang/tg/v2/example/interfaces"
"github.com/seniorGolang/tg/v2/example/interfaces/types"
"github.com/seniorGolang/tg/v2/example/transport/viewer"
"time"
)
type loggerUser struct {
next interfaces.User
}
func loggerMiddlewareUser() MiddlewareUser {
return func(next interfaces.User) interfaces.User {
return &loggerUser{next: next}
}
}
func (m loggerUser) GetUser(ctx context.Context, cookie string, userAgent string) (user *types.User, err error) {
logger := log.Ctx(ctx).With().Str("service", "User").Str("method", "getUser").Logger()
defer func(begin time.Time) {
logHandle := func(ev *zerolog.Event) {
fields := map[string]interface{}{
"request": viewer.Sprintf("%+v", requestUserGetUser{
Cookie: cookie,
UserAgent: userAgent,
}),
"response": viewer.Sprintf("%+v", responseUserGetUser{User: user}),
}
ev.Fields(fields).Str("took", time.Since(begin).String())
}
if err != nil {
logger.Error().Err(err).Func(logHandle).Msg("call getUser")
return
}
logger.Info().Func(logHandle).Msg("call getUser")
}(time.Now())
return m.next.GetUser(ctx, cookie, userAgent)
}
func (m loggerUser) CustomResponse(ctx context.Context, arg0 int, arg1 string, opts ...interface{}) (err error) {
logger := log.Ctx(ctx).With().Str("service", "User").Str("method", "customResponse").Logger()
defer func(begin time.Time) {
logHandle := func(ev *zerolog.Event) {
fields := map[string]interface{}{
"request": viewer.Sprintf("%+v", requestUserCustomResponse{
Arg0: arg0,
Arg1: arg1,
Opts: opts,
}),
"response": viewer.Sprintf("%+v", responseUserCustomResponse{}),
}
ev.Fields(fields).Str("took", time.Since(begin).String())
}
if err != nil {
logger.Error().Err(err).Func(logHandle).Msg("call customResponse")
return
}
logger.Info().Func(logHandle).Msg("call customResponse")
}(time.Now())
return m.next.CustomResponse(ctx, arg0, arg1, opts...)
}
func (m loggerUser) CustomHandler(ctx context.Context, arg0 int, arg1 string, opts ...interface{}) (err error) {
logger := log.Ctx(ctx).With().Str("service", "User").Str("method", "customHandler").Logger()
defer func(begin time.Time) {
logHandle := func(ev *zerolog.Event) {
fields := map[string]interface{}{
"request": viewer.Sprintf("%+v", requestUserCustomHandler{
Arg0: arg0,
Arg1: arg1,
Opts: opts,
}),
"response": viewer.Sprintf("%+v", responseUserCustomHandler{}),
}
ev.Fields(fields).Str("took", time.Since(begin).String())
}
if err != nil {
logger.Error().Err(err).Func(logHandle).Msg("call customHandler")
return
}
logger.Info().Func(logHandle).Msg("call customHandler")
}(time.Now())
return m.next.CustomHandler(ctx, arg0, arg1, opts...)
}