1
0
Fork 0
mirror of https://github.com/kyverno/kyverno.git synced 2025-03-09 01:16:55 +00:00
kyverno/pkg/clients/kube/policyv1beta1/evictions/resource.generated.go
Charles-Edouard Brétéché ecbdaae292
feat: add logging support to instrumented clients (#5438)
* feat: add discovery support in instrumented clients

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* fix tracing

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* feat: add logging support to instrumented clients

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>
Signed-off-by: Charles-Edouard Brétéché <charled.breteche@gmail.com>
2022-11-22 15:12:30 +00:00

80 lines
2.5 KiB
Go

package resource
import (
context "context"
"fmt"
"time"
"github.com/go-logr/logr"
"github.com/kyverno/kyverno/pkg/metrics"
"github.com/kyverno/kyverno/pkg/tracing"
"go.opentelemetry.io/otel/attribute"
"go.opentelemetry.io/otel/codes"
"go.uber.org/multierr"
k8s_io_api_policy_v1beta1 "k8s.io/api/policy/v1beta1"
k8s_io_client_go_kubernetes_typed_policy_v1beta1 "k8s.io/client-go/kubernetes/typed/policy/v1beta1"
)
func WithLogging(inner k8s_io_client_go_kubernetes_typed_policy_v1beta1.EvictionInterface, logger logr.Logger) k8s_io_client_go_kubernetes_typed_policy_v1beta1.EvictionInterface {
return &withLogging{inner, logger}
}
func WithMetrics(inner k8s_io_client_go_kubernetes_typed_policy_v1beta1.EvictionInterface, recorder metrics.Recorder) k8s_io_client_go_kubernetes_typed_policy_v1beta1.EvictionInterface {
return &withMetrics{inner, recorder}
}
func WithTracing(inner k8s_io_client_go_kubernetes_typed_policy_v1beta1.EvictionInterface, client, kind string) k8s_io_client_go_kubernetes_typed_policy_v1beta1.EvictionInterface {
return &withTracing{inner, client, kind}
}
type withLogging struct {
inner k8s_io_client_go_kubernetes_typed_policy_v1beta1.EvictionInterface
logger logr.Logger
}
func (c *withLogging) Evict(arg0 context.Context, arg1 *k8s_io_api_policy_v1beta1.Eviction) error {
start := time.Now()
logger := c.logger.WithValues("operation", "Evict")
ret0 := c.inner.Evict(arg0, arg1)
if err := multierr.Combine(ret0); err != nil {
logger.Error(err, "Evict failed", "duration", time.Since(start))
} else {
logger.Info("Evict done", "duration", time.Since(start))
}
return ret0
}
type withMetrics struct {
inner k8s_io_client_go_kubernetes_typed_policy_v1beta1.EvictionInterface
recorder metrics.Recorder
}
func (c *withMetrics) Evict(arg0 context.Context, arg1 *k8s_io_api_policy_v1beta1.Eviction) error {
defer c.recorder.Record("evict")
return c.inner.Evict(arg0, arg1)
}
type withTracing struct {
inner k8s_io_client_go_kubernetes_typed_policy_v1beta1.EvictionInterface
client string
kind string
}
func (c *withTracing) Evict(arg0 context.Context, arg1 *k8s_io_api_policy_v1beta1.Eviction) error {
ctx, span := tracing.StartSpan(
arg0,
"",
fmt.Sprintf("KUBE %s/%s/%s", c.client, c.kind, "Evict"),
attribute.String("client", c.client),
attribute.String("kind", c.kind),
attribute.String("operation", "Evict"),
)
defer span.End()
arg0 = ctx
ret0 := c.inner.Evict(arg0, arg1)
if ret0 != nil {
span.RecordError(ret0)
span.SetStatus(codes.Error, ret0.Error())
}
return ret0
}