2024-03-12 09:48:04 +01:00
|
|
|
package observability
|
2018-01-25 16:34:02 +01:00
|
|
|
|
|
|
|
import (
|
|
|
|
"bufio"
|
|
|
|
"net"
|
|
|
|
"net/http"
|
|
|
|
)
|
|
|
|
|
2022-11-16 11:38:07 +01:00
|
|
|
// newStatusCodeRecorder returns an initialized statusCodeRecoder.
|
|
|
|
func newStatusCodeRecorder(rw http.ResponseWriter, status int) *statusCodeRecorder {
|
|
|
|
return &statusCodeRecorder{rw, status}
|
2021-08-19 18:02:07 +02:00
|
|
|
}
|
|
|
|
|
2022-11-16 11:38:07 +01:00
|
|
|
type statusCodeRecorder struct {
|
2018-01-25 16:34:02 +01:00
|
|
|
http.ResponseWriter
|
|
|
|
status int
|
|
|
|
}
|
|
|
|
|
|
|
|
// WriteHeader captures the status code for later retrieval.
|
2022-11-16 11:38:07 +01:00
|
|
|
func (s *statusCodeRecorder) WriteHeader(status int) {
|
2018-01-25 16:34:02 +01:00
|
|
|
s.status = status
|
|
|
|
s.ResponseWriter.WriteHeader(status)
|
|
|
|
}
|
|
|
|
|
2020-05-11 12:06:07 +02:00
|
|
|
// Status get response status.
|
2022-11-16 11:38:07 +01:00
|
|
|
func (s *statusCodeRecorder) Status() int {
|
2018-01-25 16:34:02 +01:00
|
|
|
return s.status
|
|
|
|
}
|
|
|
|
|
2020-05-11 12:06:07 +02:00
|
|
|
// Hijack hijacks the connection.
|
2022-11-16 11:38:07 +01:00
|
|
|
func (s *statusCodeRecorder) Hijack() (net.Conn, *bufio.ReadWriter, error) {
|
2018-01-25 16:34:02 +01:00
|
|
|
return s.ResponseWriter.(http.Hijacker).Hijack()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Flush sends any buffered data to the client.
|
2022-11-16 11:38:07 +01:00
|
|
|
func (s *statusCodeRecorder) Flush() {
|
2018-01-25 16:34:02 +01:00
|
|
|
if flusher, ok := s.ResponseWriter.(http.Flusher); ok {
|
|
|
|
flusher.Flush()
|
|
|
|
}
|
|
|
|
}
|