diff --git a/.changelog/20345.txt b/.changelog/20345.txt new file mode 100644 index 0000000000000..b2fcc5271f0f0 --- /dev/null +++ b/.changelog/20345.txt @@ -0,0 +1,3 @@ +```release-note:bug + audit-logs: **(Enterprise Only)** Fixes non ASCII characters in audit logs because of gzip. +``` diff --git a/agent/http.go b/agent/http.go index 887a27a38c9a9..0e5e2ffdc5d21 100644 --- a/agent/http.go +++ b/agent/http.go @@ -187,7 +187,9 @@ func (s *HTTPHandlers) handler() http.Handler { // Register the wrapper. wrapper := func(resp http.ResponseWriter, req *http.Request) { start := time.Now() - handler(resp, req) + + // this method is implemented by different flavours of consul e.g. oss, ce. ent. + s.enterpriseRequest(resp, req, handler) labels := []metrics.Label{{Name: "method", Value: req.Method}, {Name: "path", Value: path_label}} metrics.MeasureSinceWithLabels([]string{"api", "http"}, start, labels) @@ -299,7 +301,6 @@ func (s *HTTPHandlers) handler() http.Handler { h = mux } - h = s.enterpriseHandler(h) h = withRemoteAddrHandler(h) s.h = &wrappedMux{ mux: mux, diff --git a/agent/http_ce.go b/agent/http_ce.go index d9c233226c491..bce44a68498f0 100644 --- a/agent/http_ce.go +++ b/agent/http_ce.go @@ -96,9 +96,9 @@ func parseACLAuthMethodEnterpriseMeta(req *http.Request, _ *structs.ACLAuthMetho return nil } -// enterpriseHandler is a noop for the enterprise implementation. we pass the original back -func (s *HTTPHandlers) enterpriseHandler(next http.Handler) http.Handler { - return next +func (s *HTTPHandlers) enterpriseRequest(w http.ResponseWriter, req *http.Request, handler func(http.ResponseWriter, *http.Request)) { + // no special handling for CE. Calling the default handler with default params. + handler(w, req) } // uiTemplateDataTransform returns an optional uiserver.UIDataTransform to allow