/
user-metrics.go
66 lines (48 loc) · 2.14 KB
/
user-metrics.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
// GENERATED BY 'T'ransport 'G'enerator. DO NOT EDIT.
package transport
import (
"context"
"fmt"
"github.com/go-kit/kit/metrics"
"github.com/seniorGolang/tg/v2/example/interfaces"
"github.com/seniorGolang/tg/v2/example/interfaces/types"
"time"
)
type metricsUser struct {
next interfaces.User
requestCount metrics.Counter
requestCountAll metrics.Counter
requestLatency metrics.Histogram
}
func metricsMiddlewareUser(next interfaces.User) interfaces.User {
return &metricsUser{
next: next,
requestCount: RequestCount.With("service", "User"),
requestCountAll: RequestCountAll.With("service", "User"),
requestLatency: RequestLatency.With("service", "User"),
}
}
func (m metricsUser) GetUser(ctx context.Context, cookie string, userAgent string) (user *types.User, err error) {
defer func(begin time.Time) {
m.requestLatency.With("method", "getUser", "success", fmt.Sprint(err == nil)).Observe(time.Since(begin).Seconds())
}(time.Now())
defer m.requestCount.With("method", "getUser", "success", fmt.Sprint(err == nil)).Add(1)
m.requestCountAll.With("method", "getUser").Add(1)
return m.next.GetUser(ctx, cookie, userAgent)
}
func (m metricsUser) CustomResponse(ctx context.Context, arg0 int, arg1 string, opts ...interface{}) (err error) {
defer func(begin time.Time) {
m.requestLatency.With("method", "customResponse", "success", fmt.Sprint(err == nil)).Observe(time.Since(begin).Seconds())
}(time.Now())
defer m.requestCount.With("method", "customResponse", "success", fmt.Sprint(err == nil)).Add(1)
m.requestCountAll.With("method", "customResponse").Add(1)
return m.next.CustomResponse(ctx, arg0, arg1, opts...)
}
func (m metricsUser) CustomHandler(ctx context.Context, arg0 int, arg1 string, opts ...interface{}) (err error) {
defer func(begin time.Time) {
m.requestLatency.With("method", "customHandler", "success", fmt.Sprint(err == nil)).Observe(time.Since(begin).Seconds())
}(time.Now())
defer m.requestCount.With("method", "customHandler", "success", fmt.Sprint(err == nil)).Add(1)
m.requestCountAll.With("method", "customHandler").Add(1)
return m.next.CustomHandler(ctx, arg0, arg1, opts...)
}