[release-4.1] Use responsewriter.UserProvidedDecorator instead of auto flush response (#6175)
Use responsewriter.UserProvidedDecorator instead of auto flush response Signed-off-by: hongming <coder.scala@gmail.com> Co-authored-by: hongming <coder.scala@gmail.com>
This commit is contained in:
committed by
GitHub
parent
dad35f7389
commit
de786c4b84
@@ -25,6 +25,7 @@ import (
|
||||
"k8s.io/apimachinery/pkg/runtime"
|
||||
"k8s.io/apimachinery/pkg/types"
|
||||
"k8s.io/apiserver/pkg/apis/audit"
|
||||
"k8s.io/apiserver/pkg/endpoints/responsewriter"
|
||||
"k8s.io/klog/v2"
|
||||
clusterv1alpha1 "kubesphere.io/api/cluster/v1alpha1"
|
||||
"kubesphere.io/api/iam/v1beta1"
|
||||
@@ -398,6 +399,9 @@ func (a *auditing) eventToBytes(events []*Event) [][]byte {
|
||||
return res
|
||||
}
|
||||
|
||||
var _ http.ResponseWriter = &ResponseCapture{}
|
||||
var _ responsewriter.UserProvidedDecorator = &ResponseCapture{}
|
||||
|
||||
type ResponseCapture struct {
|
||||
http.ResponseWriter
|
||||
wroteHeader bool
|
||||
@@ -413,6 +417,10 @@ func NewResponseCapture(w http.ResponseWriter) *ResponseCapture {
|
||||
}
|
||||
}
|
||||
|
||||
func (c *ResponseCapture) Unwrap() http.ResponseWriter {
|
||||
return c.ResponseWriter
|
||||
}
|
||||
|
||||
func (c *ResponseCapture) Header() http.Header {
|
||||
return c.ResponseWriter.Header()
|
||||
}
|
||||
@@ -425,9 +433,6 @@ func (c *ResponseCapture) Write(data []byte) (int, error) {
|
||||
if err != nil {
|
||||
return n, err
|
||||
}
|
||||
if flusher, ok := c.ResponseWriter.(http.Flusher); ok {
|
||||
flusher.Flush()
|
||||
}
|
||||
return n, nil
|
||||
}
|
||||
|
||||
|
||||
@@ -8,6 +8,7 @@ package filters
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"k8s.io/apiserver/pkg/endpoints/responsewriter"
|
||||
"k8s.io/klog/v2"
|
||||
|
||||
"kubesphere.io/kubesphere/pkg/apiserver/auditing"
|
||||
@@ -44,7 +45,7 @@ func (a *auditingFilter) ServeHTTP(w http.ResponseWriter, req *http.Request) {
|
||||
|
||||
if event := a.LogRequestObject(req, info); event != nil {
|
||||
resp := auditing.NewResponseCapture(w)
|
||||
a.next.ServeHTTP(resp, req)
|
||||
a.next.ServeHTTP(responsewriter.WrapForHTTP1Or2(resp), req)
|
||||
go a.LogResponseObject(event, resp)
|
||||
} else {
|
||||
a.next.ServeHTTP(w, req)
|
||||
|
||||
@@ -13,6 +13,7 @@ import (
|
||||
"strconv"
|
||||
"time"
|
||||
|
||||
"k8s.io/apiserver/pkg/endpoints/responsewriter"
|
||||
"k8s.io/klog/v2"
|
||||
|
||||
"kubesphere.io/kubesphere/pkg/apiserver/metrics"
|
||||
@@ -20,12 +21,19 @@ import (
|
||||
"kubesphere.io/kubesphere/pkg/utils/iputil"
|
||||
)
|
||||
|
||||
var _ http.ResponseWriter = &metaResponseWriter{}
|
||||
var _ responsewriter.UserProvidedDecorator = &metaResponseWriter{}
|
||||
|
||||
type metaResponseWriter struct {
|
||||
http.ResponseWriter
|
||||
statusCode int
|
||||
size int
|
||||
}
|
||||
|
||||
func (r *metaResponseWriter) Unwrap() http.ResponseWriter {
|
||||
return r.ResponseWriter
|
||||
}
|
||||
|
||||
func newMetaResponseWriter(w http.ResponseWriter) *metaResponseWriter {
|
||||
return &metaResponseWriter{
|
||||
ResponseWriter: w,
|
||||
@@ -48,9 +56,6 @@ func (r *metaResponseWriter) Write(b []byte) (int, error) {
|
||||
if err != nil {
|
||||
return size, err
|
||||
}
|
||||
if flusher, ok := r.ResponseWriter.(http.Flusher); ok {
|
||||
flusher.Flush()
|
||||
}
|
||||
return size, nil
|
||||
}
|
||||
|
||||
@@ -66,7 +71,8 @@ func WithGlobalFilter(handler http.Handler) http.Handler {
|
||||
return http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) {
|
||||
wrapper := newMetaResponseWriter(w)
|
||||
start := time.Now()
|
||||
handler.ServeHTTP(wrapper, req)
|
||||
|
||||
handler.ServeHTTP(responsewriter.WrapForHTTP1Or2(wrapper), req)
|
||||
elapsedTime := time.Since(start)
|
||||
|
||||
// Record metrics for each request
|
||||
@@ -94,7 +100,7 @@ func WithGlobalFilter(handler http.Handler) http.Handler {
|
||||
req.Proto,
|
||||
wrapper.statusCode,
|
||||
wrapper.size,
|
||||
elapsedTime.Microseconds(),
|
||||
elapsedTime.Milliseconds(),
|
||||
)
|
||||
})
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user