forked from go-playground/lars
-
Notifications
You must be signed in to change notification settings - Fork 0
/
response.go
118 lines (102 loc) · 3.4 KB
/
response.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
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
116
117
118
package lars
import (
"bufio"
"io"
"log"
"net"
"net/http"
)
// Response struct contains methods and to capture
// extra data about the http request and more efficiently
// reset underlying writer object... it does comply with
// the http.ResponseWriter interface
type Response struct {
http.ResponseWriter
status int
size int64
committed bool
context Context
}
// newResponse creates a new Response for testing purposes
func newResponse(w http.ResponseWriter, context Context) *Response {
return &Response{ResponseWriter: w, context: context}
}
// SetWriter sets the provided writer as the new *Response http.ResponseWriter
func (r *Response) SetWriter(w http.ResponseWriter) {
r.ResponseWriter = w
}
// Writer return the *Response's http.ResponseWriter object.
// Usually only used when creating middleware.
func (r *Response) Writer() http.ResponseWriter {
return r.ResponseWriter
}
// Header returns the header map that will be sent by
// WriteHeader. Changing the header after a call to
// WriteHeader (or Write) has no effect unless the modified
// headers were declared as trailers by setting the
// "Trailer" header before the call to WriteHeader (see example).
// To suppress implicit *Response headers, set their value to nil.
func (r *Response) Header() http.Header {
return r.ResponseWriter.Header()
}
// WriteHeader sends an HTTP *Response header with status code.
// If WriteHeader is not called explicitly, the first call to Write
// will trigger an implicit WriteHeader(http.StatusOK).
// Thus explicit calls to WriteHeader are mainly used to
// send error codes.
func (r *Response) WriteHeader(code int) {
if r.committed {
log.Println("response already committed")
return
}
r.status = code
r.ResponseWriter.WriteHeader(code)
r.committed = true
}
// Write writes the data to the connection as part of an HTTP reply.
// If WriteHeader has not yet been called, Write calls WriteHeader(http.StatusOK)
// before writing the data. If the Header does not contain a
// Content-Type line, Write adds a Content-Type set to the result of passing
// the initial 512 bytes of written data to DetectContentType.
func (r *Response) Write(b []byte) (n int, err error) {
n, err = r.ResponseWriter.Write(b)
r.size += int64(n)
return n, err
}
// WriteString write string to ResponseWriter
func (r *Response) WriteString(s string) (n int, err error) {
n, err = io.WriteString(r.ResponseWriter, s)
r.size += int64(n)
return
}
// Flush wraps response writer's Flush function.
func (r *Response) Flush() {
r.ResponseWriter.(http.Flusher).Flush()
}
// Hijack wraps response writer's Hijack function.
func (r *Response) Hijack() (net.Conn, *bufio.ReadWriter, error) {
return r.ResponseWriter.(http.Hijacker).Hijack()
}
// CloseNotify wraps response writer's CloseNotify function.
func (r *Response) CloseNotify() <-chan bool {
return r.ResponseWriter.(http.CloseNotifier).CloseNotify()
}
// Status returns the *Response's current http status code.
func (r *Response) Status() int {
return r.status
}
// Size returns the number of bytes written in the *Response
func (r *Response) Size() int64 {
return r.size
}
// Committed returns whether the *Response header has already been written to
// and if has been committed to this return.
func (r *Response) Committed() bool {
return r.committed
}
func (r *Response) reset(w http.ResponseWriter) {
r.ResponseWriter = w
r.size = 0
r.status = http.StatusOK
r.committed = false
}