forked from devopsmi/go-request
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathevents.go
More file actions
115 lines (97 loc) · 2.48 KB
/
events.go
File metadata and controls
115 lines (97 loc) · 2.48 KB
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
package request
import (
"bytes"
"fmt"
"time"
logger "github.com/blendlabs/go-logger"
)
const (
// Flag is a logger event flag.
Flag logger.Flag = "request"
// FlagResponse is a logger event flag.
FlagResponse logger.Flag = "request.response"
)
// NewRequestListener creates a new request listener.
func NewRequestListener(listener func(Event)) logger.Listener {
return func(e logger.Event) {
if typed, isTyped := e.(Event); isTyped {
listener(typed)
}
}
}
// Event is a logger event for outgoing requests.
type Event struct {
ts time.Time
req *Meta
}
// Flag returns the event flag.
func (re Event) Flag() logger.Flag {
return Flag
}
// Timestamp returns the event timestamp.
func (re Event) Timestamp() time.Time {
return re.ts
}
// Request returns the request meta.
func (re Event) Request() *Meta {
return re.req
}
// WriteText writes an outgoing request as text to a given buffer.
func (re Event) WriteText(tf logger.TextFormatter, buf *bytes.Buffer) {
buf.WriteString(fmt.Sprintf("%s %s", re.req.Verb, re.req.URL.String()))
if len(re.req.Body) > 0 {
buf.WriteRune(logger.RuneNewline)
buf.WriteString("request body")
buf.WriteRune(logger.RuneNewline)
buf.Write(re.req.Body)
}
}
// WriteJSON implements logger.JSONWritable.
func (re Event) WriteJSON() logger.JSONObj {
return logger.JSONObj{
"req": re.req,
}
}
// ResponseEvent is a response to outgoing requests.
type ResponseEvent struct {
ts time.Time
req *Meta
res *ResponseMeta
body []byte
}
// Flag returns the event flag.
func (re ResponseEvent) Flag() logger.Flag {
return FlagResponse
}
// Timestamp returns the event timestamp.
func (re ResponseEvent) Timestamp() time.Time {
return re.ts
}
// Request returns the request meta.
func (re ResponseEvent) Request() *Meta {
return re.req
}
// Response returns the response meta.
func (re ResponseEvent) Response() *ResponseMeta {
return re.res
}
// Body returns the outgoing request body.
func (re ResponseEvent) Body() []byte {
return re.body
}
// WriteText writes the event to a text writer.
func (re ResponseEvent) WriteText(tf logger.TextFormatter, buf *bytes.Buffer) {
buf.WriteString(fmt.Sprintf("%s %s %s", re.req.Verb, re.req.URL.String(), tf.ColorizeStatusCode(re.res.StatusCode)))
if len(re.body) > 0 {
buf.WriteRune(logger.RuneNewline)
buf.Write(re.body)
}
}
// WriteJSON implements logger.JSONWritable.
func (re ResponseEvent) WriteJSON() logger.JSONObj {
return logger.JSONObj{
"req": re.req,
"res": re.res,
"body": re.body,
}
}