2022-11-09 11:52:20 +01:00
|
|
|
package handlers
|
|
|
|
|
|
|
|
import (
|
2022-11-17 16:17:52 +01:00
|
|
|
"context"
|
2022-11-20 14:42:57 +01:00
|
|
|
"fmt"
|
2022-11-09 11:52:20 +01:00
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/go-logr/logr"
|
|
|
|
"github.com/kyverno/kyverno/pkg/metrics"
|
|
|
|
admissionRequests "github.com/kyverno/kyverno/pkg/metrics/admissionrequests"
|
|
|
|
admissionReviewDuration "github.com/kyverno/kyverno/pkg/metrics/admissionreviewduration"
|
2022-11-18 10:18:00 +01:00
|
|
|
"github.com/kyverno/kyverno/pkg/tracing"
|
|
|
|
"go.opentelemetry.io/otel/trace"
|
2022-11-09 11:52:20 +01:00
|
|
|
admissionv1 "k8s.io/api/admission/v1"
|
|
|
|
)
|
|
|
|
|
|
|
|
func (h AdmissionHandler) WithMetrics(metricsConfig *metrics.MetricsConfig) AdmissionHandler {
|
|
|
|
return withMetrics(metricsConfig, h)
|
|
|
|
}
|
|
|
|
|
|
|
|
func withMetrics(metricsConfig *metrics.MetricsConfig, inner AdmissionHandler) AdmissionHandler {
|
2022-11-17 16:17:52 +01:00
|
|
|
return func(ctx context.Context, logger logr.Logger, request *admissionv1.AdmissionRequest, startTime time.Time) *admissionv1.AdmissionResponse {
|
2022-11-18 10:18:00 +01:00
|
|
|
return tracing.Span1(
|
|
|
|
ctx,
|
2022-11-20 14:42:57 +01:00
|
|
|
"webhooks/handlers",
|
|
|
|
fmt.Sprintf("METRICS %s %s", request.Operation, request.Kind),
|
2022-11-18 10:18:00 +01:00
|
|
|
func(ctx context.Context, span trace.Span) *admissionv1.AdmissionResponse {
|
|
|
|
defer admissionReviewDuration.Process(metricsConfig, request, int64(time.Since(startTime)))
|
|
|
|
admissionRequests.Process(metricsConfig, request)
|
|
|
|
return inner(ctx, logger, request, startTime)
|
|
|
|
},
|
2022-11-20 14:42:57 +01:00
|
|
|
trace.WithAttributes(admissionRequestAttributes(request)...),
|
2022-11-18 10:18:00 +01:00
|
|
|
)
|
2022-11-09 11:52:20 +01:00
|
|
|
}
|
|
|
|
}
|