http/server/otelaudit/otelaudit.go (27 lines of code) (raw):
package otelaudit
import (
"net/http"
"log/slog"
"github.com/Azure/aks-middleware/http/common/logging"
)
// Middleware implements a separate OTEL audit middleware.
type Middleware struct {
next http.Handler
logger *slog.Logger
otelConfig *OtelConfig
}
// ServeHTTP wraps the request and triggers the audit event.
func (m *Middleware) ServeHTTP(w http.ResponseWriter, r *http.Request) {
customWriter := logging.NewResponseWriter(w)
ctx := r.Context()
m.next.ServeHTTP(customWriter, r)
errorMsg := customWriter.Buf.String()
// Call the OTEL audit event sender.
SendOtelAuditEvent(m.logger, m.otelConfig, ctx, customWriter.StatusCode, r, errorMsg)
}
// NewMiddleware returns a middleware function to add OTEL audit logging.
func NewOtelAuditLogging(logger *slog.Logger, otelConfig *OtelConfig) func(next http.Handler) http.Handler {
return func(next http.Handler) http.Handler {
return &Middleware{
next: next,
logger: logger,
otelConfig: otelConfig,
}
}
}