/
external_dependency_round_tripper.go
55 lines (44 loc) · 1.4 KB
/
external_dependency_round_tripper.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
// Copyright © 2020 by PACE Telematics GmbH. All rights reserved.
// Created at 2020/12/14 by Vincent Landgraf
package transport
import (
"net/http"
"time"
"github.com/pace/bricks/http/middleware"
)
// ExternalDependencyRoundTripper greps external dependency headers and
// attach them to the currect context
type ExternalDependencyRoundTripper struct {
name string
transport http.RoundTripper
}
func NewExternalDependencyRoundTripper(name string) *ExternalDependencyRoundTripper {
return &ExternalDependencyRoundTripper{name: name}
}
// Transport returns the RoundTripper to make HTTP requests
func (l *ExternalDependencyRoundTripper) Transport() http.RoundTripper {
return l.transport
}
// SetTransport sets the RoundTripper to make HTTP requests
func (l *ExternalDependencyRoundTripper) SetTransport(rt http.RoundTripper) {
l.transport = rt
}
// RoundTrip executes a single HTTP transaction via Transport()
func (l *ExternalDependencyRoundTripper) RoundTrip(req *http.Request) (*http.Response, error) {
start := time.Now()
resp, err := l.Transport().RoundTrip(req)
elapsed := time.Since(start)
ec := middleware.ExternalDependencyContextFromContext(req.Context())
if ec != nil {
if l.name != "" {
ec.AddDependency(l.name, elapsed)
}
if resp != nil {
header := resp.Header.Get(middleware.ExternalDependencyHeaderName)
if header != "" {
ec.Parse(header)
}
}
}
return resp, err
}