mirror of
https://github.com/labstack/echo.git
synced 2025-01-12 01:22:21 +02:00
87b24d3b7e
Set size to 0 when response reset Prevents logged size accumulating with each request
83 lines
1.5 KiB
Go
83 lines
1.5 KiB
Go
package echo
|
|
|
|
import (
|
|
"bufio"
|
|
"log"
|
|
"net"
|
|
"net/http"
|
|
|
|
"github.com/labstack/gommon/color"
|
|
)
|
|
|
|
type (
|
|
Response struct {
|
|
writer http.ResponseWriter
|
|
status int
|
|
size int64
|
|
committed bool
|
|
}
|
|
)
|
|
|
|
func NewResponse(w http.ResponseWriter) *Response {
|
|
return &Response{writer: w}
|
|
}
|
|
|
|
func (r *Response) Header() http.Header {
|
|
return r.writer.Header()
|
|
}
|
|
|
|
func (r *Response) SetWriter(w http.ResponseWriter) {
|
|
r.writer = w
|
|
}
|
|
|
|
func (r *Response) Writer() http.ResponseWriter {
|
|
return r.writer
|
|
}
|
|
|
|
func (r *Response) WriteHeader(code int) {
|
|
if r.committed {
|
|
// TODO: Warning
|
|
log.Printf("echo => %s", color.Yellow("response already committed"))
|
|
return
|
|
}
|
|
r.status = code
|
|
r.writer.WriteHeader(code)
|
|
r.committed = true
|
|
}
|
|
|
|
func (r *Response) Write(b []byte) (n int, err error) {
|
|
n, err = r.writer.Write(b)
|
|
r.size += int64(n)
|
|
return n, err
|
|
}
|
|
|
|
// Flush wraps response writer's Flush function.
|
|
func (r *Response) Flush() {
|
|
r.writer.(http.Flusher).Flush()
|
|
}
|
|
|
|
// Hijack wraps response writer's Hijack function.
|
|
func (r *Response) Hijack() (net.Conn, *bufio.ReadWriter, error) {
|
|
return r.writer.(http.Hijacker).Hijack()
|
|
}
|
|
|
|
// CloseNotify wraps response writer's CloseNotify function.
|
|
func (r *Response) CloseNotify() <-chan bool {
|
|
return r.writer.(http.CloseNotifier).CloseNotify()
|
|
}
|
|
|
|
func (r *Response) Status() int {
|
|
return r.status
|
|
}
|
|
|
|
func (r *Response) Size() int64 {
|
|
return r.size
|
|
}
|
|
|
|
func (r *Response) reset(w http.ResponseWriter) {
|
|
r.writer = w
|
|
r.size = 0
|
|
r.status = http.StatusOK
|
|
r.committed = false
|
|
}
|