From 524dfd23d9e0b334cae0a09fa908f8199fa7e6b0 Mon Sep 17 00:00:00 2001 From: Cedric Kienzler Date: Tue, 6 Jun 2023 14:17:14 +0200 Subject: [PATCH 1/2] refactor to zapLog --- controllers/redirect_controller.go | 20 ++--- controllers/shortlink_controller.go | 14 ++-- go.mod | 14 ++-- go.sum | 16 ++++ main.go | 86 +++++++++++++------- pkg/client/authenticated_shortlink_client.go | 8 +- pkg/controller/handle_create_shortlink.go | 12 ++- pkg/controller/handle_delete_shortlink.go | 10 ++- pkg/controller/handle_get_shortlink.go | 8 +- pkg/controller/handle_list_shortlink.go | 6 +- pkg/controller/handle_shortlink.go | 10 ++- pkg/controller/handle_update_shortlink.go | 14 +++- pkg/controller/shortlink-controller.go | 10 +-- pkg/observability/helpers.go | 10 +-- pkg/observability/opentelemetry.go | 29 ++++++- pkg/router/router.go | 10 ++- 16 files changed, 191 insertions(+), 86 deletions(-) diff --git a/controllers/redirect_controller.go b/controllers/redirect_controller.go index 8f0eaf3..911ebeb 100644 --- a/controllers/redirect_controller.go +++ b/controllers/redirect_controller.go @@ -22,6 +22,7 @@ import ( "go.opentelemetry.io/otel/attribute" "go.opentelemetry.io/otel/trace" + "go.uber.org/zap" networkingv1 "k8s.io/api/networking/v1" k8serrors "k8s.io/apimachinery/pkg/api/errors" "k8s.io/apimachinery/pkg/runtime" @@ -33,7 +34,6 @@ import ( redirectclient "github.com/cedi/urlshortener/pkg/client" "github.com/cedi/urlshortener/pkg/observability" redirectpkg "github.com/cedi/urlshortener/pkg/redirect" - "github.com/go-logr/logr" "github.com/pkg/errors" ) @@ -43,17 +43,17 @@ type RedirectReconciler struct { rClient *redirectclient.RedirectClient scheme *runtime.Scheme - log *logr.Logger + zapLog *zap.Logger tracer trace.Tracer } // NewRedirectReconciler returns a new RedirectReconciler -func NewRedirectReconciler(client client.Client, rClient *redirectclient.RedirectClient, scheme *runtime.Scheme, log *logr.Logger, tracer trace.Tracer) *RedirectReconciler { +func NewRedirectReconciler(client client.Client, rClient *redirectclient.RedirectClient, scheme *runtime.Scheme, zapLog *zap.Logger, tracer trace.Tracer) *RedirectReconciler { return &RedirectReconciler{ client: client, rClient: rClient, scheme: scheme, - log: log, + zapLog: zapLog, tracer: tracer, } } @@ -86,7 +86,7 @@ func (r *RedirectReconciler) Reconcile(ctx context.Context, req ctrl.Request) (c span.SetAttributes(attribute.String("redirect", req.NamespacedName.String())) - log := r.log.WithName("reconciler").WithValues("redirect", req.NamespacedName) + log := r.zapLog.Sugar().With(zap.String("name", "reconciler"), zap.String("redirect", req.NamespacedName.String())) // Monitor the number of redirects if redirectList, err := r.rClient.List(ctx); redirectList != nil && err == nil { @@ -100,19 +100,19 @@ func (r *RedirectReconciler) Reconcile(ctx context.Context, req ctrl.Request) (c // Request object not found, could have been deleted after reconcile request. // Owned objects are automatically garbage collected. For additional cleanup logic use finalizers. // Return and don't requeue - observability.RecordInfo(span, &log, "Shortlink resource not found. Ignoring since object must be deleted") + observability.RecordInfo(span, log, "Shortlink resource not found. Ignoring since object must be deleted") return ctrl.Result{}, nil } // Error reading the object - requeue the request. - observability.RecordError(span, &log, err, "Failed to fetch Redirect resource") + observability.RecordError(span, log, err, "Failed to fetch Redirect resource") return ctrl.Result{}, err } // Check if the ingress already exists, if not create a new one ingress, err := r.upsertRedirectIngress(ctx, redirect) if err != nil { - observability.RecordError(span, &log, err, "Failed to upsert redirect ingress") + observability.RecordError(span, log, err, "Failed to upsert redirect ingress") } // Update the Redirect status with the ingress name and the target @@ -123,7 +123,7 @@ func (r *RedirectReconciler) Reconcile(ctx context.Context, req ctrl.Request) (c } if err = r.client.List(ctx, ingressList, listOpts...); err != nil { - observability.RecordError(span, &log, err, "Failed to list ingresses") + observability.RecordError(span, log, err, "Failed to list ingresses") return ctrl.Result{}, err } @@ -132,7 +132,7 @@ func (r *RedirectReconciler) Reconcile(ctx context.Context, req ctrl.Request) (c redirect.Status.Target = ingress.ObjectMeta.Annotations["nginx.ingress.kubernetes.io/permanent-redirect"] err = r.client.Status().Update(ctx, redirect) if err != nil { - observability.RecordError(span, &log, err, "Failed to update Redirect status") + observability.RecordError(span, log, err, "Failed to update Redirect status") return ctrl.Result{}, err } diff --git a/controllers/shortlink_controller.go b/controllers/shortlink_controller.go index c7ea8ea..cc3e1d4 100644 --- a/controllers/shortlink_controller.go +++ b/controllers/shortlink_controller.go @@ -22,6 +22,7 @@ import ( "go.opentelemetry.io/otel/attribute" "go.opentelemetry.io/otel/trace" + "go.uber.org/zap" "k8s.io/apimachinery/pkg/api/errors" "k8s.io/apimachinery/pkg/runtime" @@ -30,23 +31,22 @@ import ( v1alpha1 "github.com/cedi/urlshortener/api/v1alpha1" shortlinkclient "github.com/cedi/urlshortener/pkg/client" "github.com/cedi/urlshortener/pkg/observability" - "github.com/go-logr/logr" ) // ShortLinkReconciler reconciles a ShortLink object type ShortLinkReconciler struct { client *shortlinkclient.ShortlinkClient scheme *runtime.Scheme - log *logr.Logger + zapLog *zap.Logger tracer trace.Tracer } // NewShortLinkReconciler returns a new ShortLinkReconciler -func NewShortLinkReconciler(client *shortlinkclient.ShortlinkClient, scheme *runtime.Scheme, log *logr.Logger, tracer trace.Tracer) *ShortLinkReconciler { +func NewShortLinkReconciler(client *shortlinkclient.ShortlinkClient, scheme *runtime.Scheme, zapLog *zap.Logger, tracer trace.Tracer) *ShortLinkReconciler { return &ShortLinkReconciler{ client: client, scheme: scheme, - log: log, + zapLog: zapLog, tracer: tracer, } } @@ -76,15 +76,15 @@ func (r *ShortLinkReconciler) Reconcile(ctx context.Context, req ctrl.Request) ( span.SetAttributes(attribute.String("shortlink", req.Name)) - log := r.log.WithName("reconciler").WithValues("shortlink", req.NamespacedName.String()) + log := r.zapLog.Sugar().With(zap.String("name", "reconciler"), zap.String("shortlink", req.NamespacedName.String())) // Get ShortLink from etcd shortlink, err := r.client.GetNamespaced(ctx, req.NamespacedName) if err != nil || shortlink == nil { if errors.IsNotFound(err) { - observability.RecordInfo(span, &log, "Shortlink resource not found. Ignoring since object must be deleted") + observability.RecordInfo(span, log, "Shortlink resource not found. Ignoring since object must be deleted") } else { - observability.RecordError(span, &log, err, "Failed to fetch ShortLink resource") + observability.RecordError(span, log, err, "Failed to fetch ShortLink resource") } } diff --git a/go.mod b/go.mod index 66bee27..5cd3feb 100644 --- a/go.mod +++ b/go.mod @@ -13,12 +13,12 @@ require ( github.com/swaggo/gin-swagger v1.5.3 github.com/swaggo/swag v1.8.10 go.opentelemetry.io/contrib/instrumentation/github.com/gin-gonic/gin/otelgin v0.39.0 - go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.40.0 - go.opentelemetry.io/otel v1.15.1 + go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.42.0 + go.opentelemetry.io/otel v1.16.0 go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.15.1 go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.15.1 go.opentelemetry.io/otel/sdk v1.15.1 - go.opentelemetry.io/otel/trace v1.15.1 + go.opentelemetry.io/otel/trace v1.16.0 golang.org/x/exp v0.0.0-20230304125523-9ff063c70017 k8s.io/api v0.26.2 k8s.io/apimachinery v0.26.2 @@ -28,7 +28,7 @@ require ( require ( github.com/felixge/httpsnoop v1.0.3 // indirect - go.opentelemetry.io/otel/metric v0.37.0 // indirect + go.opentelemetry.io/otel/metric v1.16.0 // indirect ) require ( @@ -83,10 +83,12 @@ require ( github.com/spf13/pflag v1.0.5 // indirect github.com/twitchyliquid64/golang-asm v0.15.1 // indirect github.com/ugorji/go/codec v1.2.9 // indirect + github.com/uptrace/opentelemetry-go-extra/otelutil v0.2.1 // indirect + github.com/uptrace/opentelemetry-go-extra/otelzap v0.2.1 // indirect go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.15.1 // indirect go.opentelemetry.io/proto/otlp v0.19.0 // indirect - go.uber.org/atomic v1.10.0 // indirect - go.uber.org/multierr v1.9.0 // indirect + go.uber.org/atomic v1.11.0 // indirect + go.uber.org/multierr v1.11.0 // indirect go.uber.org/zap v1.24.0 // indirect golang.org/x/arch v0.0.0-20210923205945-b76863e36670 // indirect golang.org/x/crypto v0.6.0 // indirect diff --git a/go.sum b/go.sum index 46ca070..3271fb7 100644 --- a/go.sum +++ b/go.sum @@ -387,6 +387,10 @@ github.com/ugorji/go v1.2.7/go.mod h1:nF9osbDWLy6bDVv/Rtoh6QgnvNDpmCalQV5urGCCS6 github.com/ugorji/go/codec v1.2.7/go.mod h1:WGN1fab3R1fzQlVQTkfxVtIBhWDRqOviHU95kRgeqEY= github.com/ugorji/go/codec v1.2.9 h1:rmenucSohSTiyL09Y+l2OCk+FrMxGMzho2+tjr5ticU= github.com/ugorji/go/codec v1.2.9/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= +github.com/uptrace/opentelemetry-go-extra/otelutil v0.2.1 h1:qjljyY//UH064+gQDHh5U7M1Jh6b+iQpJUWVAuRJ04A= +github.com/uptrace/opentelemetry-go-extra/otelutil v0.2.1/go.mod h1:7YSrHCmYPHIXjTWnKSU7EGT0TFEcm3WwSeQquwCGg38= +github.com/uptrace/opentelemetry-go-extra/otelzap v0.2.1 h1:HhKd/kmL1JuBK3zPr3gT/Ku7lvvBsnsy8NtQ+uG5rRM= +github.com/uptrace/opentelemetry-go-extra/otelzap v0.2.1/go.mod h1:GiIWZ+UVlFnAik/QCTc7TjsLA+YV1m94ls3G1Q7fKRY= github.com/urfave/cli/v2 v2.3.0/go.mod h1:LJmUH05zAU44vOAcrfzZQKsZbVcdbOG8rtL3/XcUArI= github.com/xeipuuv/gojsonpointer v0.0.0-20180127040702-4e3ac2762d5f/go.mod h1:N2zxlSyiKSe5eX1tZViRH5QA0qijqEDrYZiPEAiq3wU= github.com/xeipuuv/gojsonreference v0.0.0-20180127040603-bd5ef7bd5415/go.mod h1:GwrjFmJcFw6At/Gs6z4yjiIwzuJ1/+UwLxMQDVQXShQ= @@ -406,10 +410,14 @@ go.opentelemetry.io/contrib/instrumentation/github.com/gin-gonic/gin/otelgin v0. go.opentelemetry.io/contrib/instrumentation/github.com/gin-gonic/gin/otelgin v0.39.0/go.mod h1:dbx2pPD/jZWsnCz7ogHKY2mmHHnRU4bkjOVsw1V8x/o= go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.40.0 h1:lE9EJyw3/JhrjWH/hEy9FptnalDQgj7vpbgC2KCCCxE= go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.40.0/go.mod h1:pcQ3MM3SWvrA71U4GDqv9UFDJ3HQsW7y5ZO3tDTlUdI= +go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.42.0 h1:pginetY7+onl4qN1vl0xW/V/v6OBZ0vVdH+esuJgvmM= +go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.42.0/go.mod h1:XiYsayHc36K3EByOO6nbAXnAWbrUxdjUROCEeeROOH8= go.opentelemetry.io/contrib/propagators/b3 v1.14.0 h1:0SBc35DESy/YXShxFtu3634OwcEWJoGzSA8Hx/NbOo8= go.opentelemetry.io/otel v1.7.0/go.mod h1:5BdUoMIz5WEs0vt0CUEMtSSaTSHBBVwrhnz7+nrD5xk= go.opentelemetry.io/otel v1.15.1 h1:3Iwq3lfRByPaws0f6bU3naAqOR1n5IeDWd9390kWHa8= go.opentelemetry.io/otel v1.15.1/go.mod h1:mHHGEHVDLal6YrKMmk9LqC4a3sF5g+fHfrttQIB1NTc= +go.opentelemetry.io/otel v1.16.0 h1:Z7GVAX/UkAXPKsy94IU+i6thsQS4nb7LviLpnaNeW8s= +go.opentelemetry.io/otel v1.16.0/go.mod h1:vl0h9NUa1D5s1nv3A5vZOYWn8av4K8Ml6JDeHrT/bx4= go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.15.1 h1:XYDQtNzdb2T4uM1pku2m76eSMDJgqhJ+6KzkqgQBALc= go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.15.1/go.mod h1:uOTV75+LOzV+ODmL8ahRLWkFA3eQcSC2aAsbxIu4duk= go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.15.1 h1:tyoeaUh8REKay72DVYsSEBYV18+fGONe+YYPaOxgLoE= @@ -418,23 +426,31 @@ go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.15.1 h1:pnJfH go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.15.1/go.mod h1:cC3Eu2V56zXY09YlijmqDhOUnL2jVL6KKJg4PGh++dU= go.opentelemetry.io/otel/metric v0.37.0 h1:pHDQuLQOZwYD+Km0eb657A25NaRzy0a+eLyKfDXedEs= go.opentelemetry.io/otel/metric v0.37.0/go.mod h1:DmdaHfGt54iV6UKxsV9slj2bBRJcKC1B1uvDLIioc1s= +go.opentelemetry.io/otel/metric v1.16.0 h1:RbrpwVG1Hfv85LgnZ7+txXioPDoh6EdbZHo26Q3hqOo= +go.opentelemetry.io/otel/metric v1.16.0/go.mod h1:QE47cpOmkwipPiefDwo2wDzwJrlfxxNYodqc4xnGCo4= go.opentelemetry.io/otel/sdk v1.7.0/go.mod h1:uTEOTwaqIVuTGiJN7ii13Ibp75wJmYUDe374q6cZwUU= go.opentelemetry.io/otel/sdk v1.15.1 h1:5FKR+skgpzvhPQHIEfcwMYjCBr14LWzs3uSqKiQzETI= go.opentelemetry.io/otel/sdk v1.15.1/go.mod h1:8rVtxQfrbmbHKfqzpQkT5EzZMcbMBwTzNAggbEAM0KA= go.opentelemetry.io/otel/trace v1.7.0/go.mod h1:fzLSB9nqR2eXzxPXb2JW9IKE+ScyXA48yyE4TNvoHqU= go.opentelemetry.io/otel/trace v1.15.1 h1:uXLo6iHJEzDfrNC0L0mNjItIp06SyaBQxu5t3xMlngY= go.opentelemetry.io/otel/trace v1.15.1/go.mod h1:IWdQG/5N1x7f6YUlmdLeJvH9yxtuJAfc4VW5Agv9r/8= +go.opentelemetry.io/otel/trace v1.16.0 h1:8JRpaObFoW0pxuVPapkgH8UhHQj+bJW8jJsCZEu5MQs= +go.opentelemetry.io/otel/trace v1.16.0/go.mod h1:Yt9vYq1SdNz3xdjZZK7wcXv1qv2pwLkqr2QVwea0ef0= go.opentelemetry.io/proto/otlp v0.7.0/go.mod h1:PqfVotwruBrMGOCsRd/89rSnXhoiJIqeYNgFYFoEGnI= go.opentelemetry.io/proto/otlp v0.19.0 h1:IVN6GR+mhC4s5yfcTbmzHYODqvWAp3ZedA2SJPI1Nnw= go.opentelemetry.io/proto/otlp v0.19.0/go.mod h1:H7XAot3MsfNsj7EXtrA2q5xSNQ10UqI405h3+duxN4U= go.uber.org/atomic v1.7.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= go.uber.org/atomic v1.10.0 h1:9qC72Qh0+3MqyJbAn8YU5xVq1frD8bn3JtD2oXtafVQ= go.uber.org/atomic v1.10.0/go.mod h1:LUxbIzbOniOlMKjJjyPfpl4v+PKK2cNJn91OQbhoJI0= +go.uber.org/atomic v1.11.0 h1:ZvwS0R+56ePWxUNi+Atn9dWONBPp/AUETXlHW0DxSjE= +go.uber.org/atomic v1.11.0/go.mod h1:LUxbIzbOniOlMKjJjyPfpl4v+PKK2cNJn91OQbhoJI0= go.uber.org/goleak v1.1.10/go.mod h1:8a7PlsEVH3e/a/GLqe5IIrQx6GzcnRmZEufDUTk4A7A= go.uber.org/goleak v1.2.0 h1:xqgm/S+aQvhWFTtR0XK3Jvg7z8kGV8P4X14IzwN3Eqk= go.uber.org/multierr v1.6.0/go.mod h1:cdWPpRnG4AhwMwsgIHip0KRBQjJy5kYEpYjJxpXp9iU= go.uber.org/multierr v1.9.0 h1:7fIwc/ZtS0q++VgcfqFDxSBZVv/Xo49/SYnDFupUwlI= go.uber.org/multierr v1.9.0/go.mod h1:X2jQV1h+kxSjClGpnseKVIxpmcjrj7MNnI0bnlfKTVQ= +go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0= +go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y= go.uber.org/zap v1.19.0/go.mod h1:xg/QME4nWcxGxrpdeYfq7UvYrLh66cuVKdrbD1XF/NI= go.uber.org/zap v1.24.0 h1:FiJd5l1UOLj0wCgbSE0rwwXHzEdAZS6hiiSnxJN/D60= go.uber.org/zap v1.24.0/go.mod h1:2kMP+WWQ8aoFoedH3T2sq6iJ2yDWpHbP0f6MQbS9Gkg= diff --git a/main.go b/main.go index 746cc77..cd38582 100644 --- a/main.go +++ b/main.go @@ -27,16 +27,16 @@ import ( // Import all Kubernetes client auth plugins (e.g. Azure, GCP, OIDC, etc.) // to ensure that exec-entrypoint and run can make use of them. + "go.uber.org/zap" "k8s.io/apimachinery/pkg/runtime" utilRuntime "k8s.io/apimachinery/pkg/util/runtime" clientGoScheme "k8s.io/client-go/kubernetes/scheme" _ "k8s.io/client-go/plugin/pkg/client/auth" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/healthz" - "sigs.k8s.io/controller-runtime/pkg/log/zap" "github.com/gin-gonic/gin" - "github.com/go-logr/logr" + "github.com/go-logr/zapr" v1alpha1 "github.com/cedi/urlshortener/api/v1alpha1" "github.com/cedi/urlshortener/controllers" @@ -78,34 +78,37 @@ func main() { var probeAddr string var bindAddr string var namespaced bool + var debug bool flag.StringVar(&metricsAddr, "metrics-bind-address", ":9110", "The address the metric endpoint binds to.") flag.StringVar(&probeAddr, "health-probe-bind-address", ":9081", "The address the probe endpoint binds to.") flag.StringVar(&bindAddr, "bind-address", ":8443", "The address the service binds to.") flag.BoolVar(&namespaced, "namespaced", true, "Restrict the urlshortener to only list resources in the current namespace") + flag.BoolVar(&debug, "debug", false, "Turn on debug logging") - opts := zap.Options{ - Development: false, // false = production mode = JSON log format - } - - opts.BindFlags(flag.CommandLine) flag.Parse() // Initialize Logging - ctrl.SetLogger(zap.New(zap.UseFlagOptions(&opts))) - setupLog := ctrl.Log.WithName("setup") - shutdownLog := ctrl.Log.WithName("shutdown") + zapLog, otelLogger, undo := observability.InitLogging(debug) + defer otelLogger.Sync() + defer undo() + + ctrl.SetLogger(zapr.NewLogger(zapLog)) // Initialize Tracing (OpenTelemetry) traceProvider, tracer, err := observability.InitTracer(serviceName, serviceVersion) if err != nil { - setupLog.Error(err, "failed initializing tracing") + zapLog.Sugar().Errorw("failed initializing tracing", + zap.Error(err), + ) os.Exit(1) } defer func() { if err := traceProvider.Shutdown(context.Background()); err != nil { - shutdownLog.Error(err, "Error shutting down tracer provider") + zapLog.Sugar().Errorw("Error shutting down tracer provider", + zap.Error(err), + ) } }() @@ -118,7 +121,9 @@ func main() { namespaceByte, err := os.ReadFile("/var/run/secrets/kubernetes.io/serviceaccount/namespace") if err != nil { span.RecordError(err) - setupLog.Error(err, "Unable to read current namespace") + zapLog.Sugar().Errorw("Error shutting down tracer provider", + zap.Error(err), + ) os.Exit(1) } span.End() @@ -140,7 +145,9 @@ func main() { if err != nil { span.RecordError(err) - setupLog.Error(err, "unable to start urlshortener") + zapLog.Sugar().Errorw("unable to start urlshortener", + zap.Error(err), + ) os.Exit(1) } @@ -159,13 +166,16 @@ func main() { shortlinkReconciler := controllers.NewShortLinkReconciler( sClient, mgr.GetScheme(), - &ctrl.Log, + zapLog, tracer, ) if err = shortlinkReconciler.SetupWithManager(mgr); err != nil { span.RecordError(err) - setupLog.Error(err, "unable to create controller", "controller", "ShortLink") + zapLog.Sugar().Errorw("unable to create controller", + zap.Error(err), + zap.String("controller", "ShortLink"), + ) os.Exit(1) } @@ -173,13 +183,16 @@ func main() { mgr.GetClient(), rClient, mgr.GetScheme(), - &ctrl.Log, + zapLog, tracer, ) if err = redirectReconciler.SetupWithManager(mgr); err != nil { span.RecordError(err) - setupLog.Error(err, "unable to create controller", "controller", "Redirect") + zapLog.Sugar().Errorw("unable to create controller", + zap.Error(err), + zap.String("controller", "Redirect"), + ) os.Exit(1) } //+kubebuilder:scaffold:builder @@ -187,52 +200,61 @@ func main() { span.End() if err := mgr.AddHealthzCheck("healthz", healthz.Ping); err != nil { - setupLog.Error(err, "unable to set up health check") + zapLog.Sugar().Errorw("unable to set up health check", + zap.Error(err), + ) os.Exit(1) } if err := mgr.AddReadyzCheck("readyz", healthz.Ping); err != nil { - setupLog.Error(err, "unable to set up ready check") + zapLog.Sugar().Errorw("unable to set up ready check", + zap.Error(err), + ) os.Exit(1) } // run our urlshortener mgr in a separate go routine go func() { - setupLog.Info("starting urlshortener") + zapLog.Info("starting urlshortener") + if err := mgr.Start(ctrl.SetupSignalHandler()); err != nil { - setupLog.Error(err, "problem running urlshortener") + zapLog.Sugar().Errorw("unable starting urlshortener", + zap.Error(err), + ) os.Exit(1) } }() shortlinkController := apiController.NewShortlinkController( - &ctrl.Log, + zapLog, tracer, sClient, ) // Init Gin Framework gin.SetMode(gin.ReleaseMode) - r, srv := router.NewGinGonicHTTPServer(bindAddr, &setupLog, serviceName) + r, srv := router.NewGinGonicHTTPServer(bindAddr, zapLog, serviceName) - setupLog.Info("Load API routes") + zapLog.Info("Load API routes") router.Load(r, shortlinkController) // run our gin server mgr in a separate go routine go func() { if err := srv.ListenAndServe(); err != nil && errors.Is(err, http.ErrServerClosed) { - setupLog.Error(err, "listen\n") + zapLog.Sugar().Errorw("failed to listen and serve", + zap.Error(err), + ) } }() - handleShutdown(srv, &shutdownLog) + handleShutdown(srv, zapLog) - shutdownLog.Info("Server exiting") + zapLog.Info("Server exiting") } // handleShutdown waits for interrupt signal and then tries to gracefully // shutdown the server with a timeout of 5 seconds. -func handleShutdown(srv *http.Server, shutdownLog *logr.Logger) { +func handleShutdown(srv *http.Server, zapLog *zap.Logger) { quit := make(chan os.Signal, 1) signal.Notify( @@ -244,7 +266,7 @@ func handleShutdown(srv *http.Server, shutdownLog *logr.Logger) { // wait (and block) until shutdown signal is received <-quit - shutdownLog.Info("Shutting down server...") + zapLog.Info("Shutting down server...") // The context is used to inform the server it has 5 seconds to finish // the request it is currently handling @@ -255,7 +277,9 @@ func handleShutdown(srv *http.Server, shutdownLog *logr.Logger) { // then srv.Shutdown(ctx) will return an error, causing us to force // the shutdown if err := srv.Shutdown(ctx); err != nil { - shutdownLog.Error(err, "Server forced to shutdown") + zapLog.Sugar().Errorw("Server forced to shutdown", + zap.Error(err), + ) os.Exit(1) } } diff --git a/pkg/client/authenticated_shortlink_client.go b/pkg/client/authenticated_shortlink_client.go index 1289aac..1b501dd 100644 --- a/pkg/client/authenticated_shortlink_client.go +++ b/pkg/client/authenticated_shortlink_client.go @@ -5,22 +5,22 @@ import ( "github.com/cedi/urlshortener/api/v1alpha1" "github.com/cedi/urlshortener/pkg/model" + "go.uber.org/zap" - "github.com/go-logr/logr" "github.com/pkg/errors" "go.opentelemetry.io/otel/attribute" "go.opentelemetry.io/otel/trace" ) type ShortlinkClientAuth struct { - log *logr.Logger + zapLog *zap.Logger tracer trace.Tracer client *ShortlinkClient } -func NewAuthenticatedShortlinkClient(log *logr.Logger, tracer trace.Tracer, client *ShortlinkClient) *ShortlinkClientAuth { +func NewAuthenticatedShortlinkClient(zapLog *zap.Logger, tracer trace.Tracer, client *ShortlinkClient) *ShortlinkClientAuth { return &ShortlinkClientAuth{ - log: log, + zapLog: zapLog, tracer: tracer, client: client, } diff --git a/pkg/controller/handle_create_shortlink.go b/pkg/controller/handle_create_shortlink.go index 3deeddf..625dd5b 100644 --- a/pkg/controller/handle_create_shortlink.go +++ b/pkg/controller/handle_create_shortlink.go @@ -12,6 +12,7 @@ import ( "github.com/gin-gonic/gin" "go.opentelemetry.io/otel/attribute" "go.opentelemetry.io/otel/trace" + "go.uber.org/zap" v1 "k8s.io/apimachinery/pkg/apis/meta/v1" ) @@ -55,6 +56,11 @@ func (s *ShortlinkController) HandleCreateShortLink(ct *gin.Context) { attribute.String("referrer", ct.Request.Referer()), ) + log := s.zapLog.Sugar() + log.With(zap.String("shortlink", shortlinkName), + zap.String("operation", "create"), + ) + bearerToken := ct.Request.Header.Get("Authorization") bearerToken = strings.TrimPrefix(bearerToken, "Bearer") bearerToken = strings.TrimPrefix(bearerToken, "token") @@ -81,19 +87,19 @@ func (s *ShortlinkController) HandleCreateShortLink(ct *gin.Context) { jsonData, err := io.ReadAll(ct.Request.Body) if err != nil { - observability.RecordError(span, s.log, err, "Failed to read request-body") + observability.RecordError(span, log, err, "Failed to read request-body") ginReturnError(ct, http.StatusInternalServerError, contentType, err.Error()) return } if err := json.Unmarshal([]byte(jsonData), &shortlink.Spec); err != nil { - observability.RecordError(span, s.log, err, "Failed to read spec-json") + observability.RecordError(span, log, err, "Failed to read spec-json") ginReturnError(ct, http.StatusInternalServerError, contentType, err.Error()) return } if err := s.authenticatedClient.Create(ctx, githubUser.Login, &shortlink); err != nil { - observability.RecordError(span, s.log, err, "Failed to create ShortLink") + observability.RecordError(span, log, err, "Failed to create ShortLink") ginReturnError(ct, http.StatusInternalServerError, contentType, err.Error()) return } diff --git a/pkg/controller/handle_delete_shortlink.go b/pkg/controller/handle_delete_shortlink.go index 7285ec8..bdd48de 100644 --- a/pkg/controller/handle_delete_shortlink.go +++ b/pkg/controller/handle_delete_shortlink.go @@ -9,6 +9,7 @@ import ( "github.com/gin-gonic/gin" "go.opentelemetry.io/otel/attribute" "go.opentelemetry.io/otel/trace" + "go.uber.org/zap" ) // HandleDeleteShortLink handles the deletion of a shortlink @@ -45,6 +46,11 @@ func (s *ShortlinkController) HandleDeleteShortLink(ct *gin.Context) { attribute.String("referrer", ct.Request.Referer()), ) + log := s.zapLog.Sugar() + log.With(zap.String("shortlink", shortlinkName), + zap.String("operation", "delete"), + ) + bearerToken := ct.Request.Header.Get("Authorization") bearerToken = strings.TrimPrefix(bearerToken, "Bearer") bearerToken = strings.TrimPrefix(bearerToken, "token") @@ -64,7 +70,7 @@ func (s *ShortlinkController) HandleDeleteShortLink(ct *gin.Context) { shortlink, err := s.authenticatedClient.Get(ctx, githubUser.Login, shortlinkName) if err != nil { - observability.RecordError(span, s.log, err, "Failed to get ShortLink") + observability.RecordError(span, log, err, "Failed to get ShortLink") statusCode := http.StatusInternalServerError @@ -89,7 +95,7 @@ func (s *ShortlinkController) HandleDeleteShortLink(ct *gin.Context) { statusCode = http.StatusNotFound } - observability.RecordError(span, s.log, err, "Failed to delete ShortLink") + observability.RecordError(span, log, err, "Failed to delete ShortLink") ginReturnError(ct, statusCode, contentType, err.Error()) return diff --git a/pkg/controller/handle_get_shortlink.go b/pkg/controller/handle_get_shortlink.go index 141084d..8b7c556 100644 --- a/pkg/controller/handle_get_shortlink.go +++ b/pkg/controller/handle_get_shortlink.go @@ -9,6 +9,7 @@ import ( "github.com/gin-gonic/gin" "go.opentelemetry.io/otel/attribute" "go.opentelemetry.io/otel/trace" + "go.uber.org/zap" ) // HandleGetShortLink returns the shortlink @@ -45,6 +46,11 @@ func (s *ShortlinkController) HandleGetShortLink(ct *gin.Context) { attribute.String("referrer", ct.Request.Referer()), ) + log := s.zapLog.Sugar() + log.With(zap.String("shortlink", shortlinkName), + zap.String("operation", "create"), + ) + bearerToken := ct.Request.Header.Get("Authorization") bearerToken = strings.TrimPrefix(bearerToken, "Bearer") bearerToken = strings.TrimPrefix(bearerToken, "token") @@ -64,7 +70,7 @@ func (s *ShortlinkController) HandleGetShortLink(ct *gin.Context) { shortlink, err := s.authenticatedClient.Get(ctx, githubUser.Login, shortlinkName) if err != nil { - observability.RecordError(span, s.log, err, "Failed to get ShortLink") + observability.RecordError(span, log, err, "Failed to get ShortLink") statusCode := http.StatusInternalServerError diff --git a/pkg/controller/handle_list_shortlink.go b/pkg/controller/handle_list_shortlink.go index af859cb..3cd3c41 100644 --- a/pkg/controller/handle_list_shortlink.go +++ b/pkg/controller/handle_list_shortlink.go @@ -9,6 +9,7 @@ import ( "github.com/gin-gonic/gin" "go.opentelemetry.io/otel/attribute" "go.opentelemetry.io/otel/trace" + "go.uber.org/zap" ) // HandleListShortLink handles the listing of @@ -43,6 +44,9 @@ func (s *ShortlinkController) HandleListShortLink(ct *gin.Context) { attribute.String("referrer", ct.Request.Referer()), ) + log := s.zapLog.Sugar() + log.With(zap.String("operation", "list")) + bearerToken := ct.Request.Header.Get("Authorization") bearerToken = strings.TrimPrefix(bearerToken, "Bearer") bearerToken = strings.TrimPrefix(bearerToken, "token") @@ -62,7 +66,7 @@ func (s *ShortlinkController) HandleListShortLink(ct *gin.Context) { shortlinkList, err := s.authenticatedClient.List(ctx, githubUser.Login) if err != nil { - observability.RecordError(span, s.log, err, "Failed to list ShortLink") + observability.RecordError(span, log, err, "Failed to list ShortLink") statusCode := http.StatusInternalServerError diff --git a/pkg/controller/handle_shortlink.go b/pkg/controller/handle_shortlink.go index c2ab5f4..3288309 100644 --- a/pkg/controller/handle_shortlink.go +++ b/pkg/controller/handle_shortlink.go @@ -9,6 +9,7 @@ import ( "github.com/gin-gonic/gin" "go.opentelemetry.io/otel/attribute" "go.opentelemetry.io/otel/trace" + "go.uber.org/zap" ) // HandleShortlink handles the shortlink and redirects according to the configuration @@ -48,17 +49,22 @@ func (s *ShortlinkController) HandleShortLink(ct *gin.Context) { attribute.String("referrer", ct.Request.Referer()), ) + log := s.zapLog.Sugar() + log.With(zap.String("shortlink", shortlinkName), + zap.String("operation", "shortlink"), + ) + ct.Header("Cache-Control", "public, max-age=900, stale-if-error=3600") // max-age = 15min; stale-if-error = 1h shortlink, err := s.client.Get(ctx, shortlinkName) if err != nil { if strings.Contains(err.Error(), "not found") { - observability.RecordError(span, s.log, err, "Path not found") + observability.RecordError(span, log, err, "Path not found") span.SetAttributes(attribute.String("path", ct.Request.URL.Path)) ct.HTML(http.StatusNotFound, "404.html", gin.H{}) } else { - observability.RecordError(span, s.log, err, "Failed to get ShortLink") + observability.RecordError(span, log, err, "Failed to get ShortLink") ct.HTML(http.StatusInternalServerError, "500.html", gin.H{}) } return diff --git a/pkg/controller/handle_update_shortlink.go b/pkg/controller/handle_update_shortlink.go index 3b91d12..adf366a 100644 --- a/pkg/controller/handle_update_shortlink.go +++ b/pkg/controller/handle_update_shortlink.go @@ -12,6 +12,7 @@ import ( "github.com/gin-gonic/gin" "go.opentelemetry.io/otel/attribute" "go.opentelemetry.io/otel/trace" + "go.uber.org/zap" ) // HandleDeleteShortLink handles the update of a shortlink @@ -49,6 +50,11 @@ func (s *ShortlinkController) HandleUpdateShortLink(ct *gin.Context) { attribute.String("referrer", ct.Request.Referer()), ) + log := s.zapLog.Sugar() + log.With(zap.String("shortlink", shortlinkName), + zap.String("operation", "update"), + ) + bearerToken := ct.Request.Header.Get("Authorization") bearerToken = strings.TrimPrefix(bearerToken, "Bearer") bearerToken = strings.TrimPrefix(bearerToken, "token") @@ -68,7 +74,7 @@ func (s *ShortlinkController) HandleUpdateShortLink(ct *gin.Context) { shortlink, err := s.authenticatedClient.Get(ctx, githubUser.Login, shortlinkName) if err != nil { - observability.RecordError(span, s.log, err, "Failed to get ShortLink") + observability.RecordError(span, log, err, "Failed to get ShortLink") statusCode := http.StatusInternalServerError @@ -90,14 +96,14 @@ func (s *ShortlinkController) HandleUpdateShortLink(ct *gin.Context) { jsonData, err := io.ReadAll(ct.Request.Body) if err != nil { - observability.RecordError(span, s.log, err, "Failed to read request-body") + observability.RecordError(span, log, err, "Failed to read request-body") ginReturnError(ct, http.StatusInternalServerError, contentType, err.Error()) return } if err := json.Unmarshal([]byte(jsonData), &shortlinkSpec); err != nil { - observability.RecordError(span, s.log, err, "Failed to read ShortLink Spec JSON") + observability.RecordError(span, log, err, "Failed to read ShortLink Spec JSON") ginReturnError(ct, http.StatusInternalServerError, contentType, err.Error()) return @@ -106,7 +112,7 @@ func (s *ShortlinkController) HandleUpdateShortLink(ct *gin.Context) { shortlink.Spec = shortlinkSpec if err := s.authenticatedClient.Update(ctx, githubUser.Login, shortlink); err != nil { - observability.RecordError(span, s.log, err, "Failed to update ShortLink") + observability.RecordError(span, log, err, "Failed to update ShortLink") ginReturnError(ct, http.StatusInternalServerError, contentType, err.Error()) return diff --git a/pkg/controller/shortlink-controller.go b/pkg/controller/shortlink-controller.go index f54133c..13aabc7 100644 --- a/pkg/controller/shortlink-controller.go +++ b/pkg/controller/shortlink-controller.go @@ -2,7 +2,7 @@ package controller import ( shortlinkClient "github.com/cedi/urlshortener/pkg/client" - "github.com/go-logr/logr" + "go.uber.org/zap" "go.opentelemetry.io/otel/trace" ) @@ -11,17 +11,17 @@ import ( type ShortlinkController struct { client *shortlinkClient.ShortlinkClient authenticatedClient *shortlinkClient.ShortlinkClientAuth - log *logr.Logger + zapLog *zap.Logger tracer trace.Tracer } // NewShortlinkController creates a new ShortlinkController -func NewShortlinkController(log *logr.Logger, tracer trace.Tracer, client *shortlinkClient.ShortlinkClient) *ShortlinkController { +func NewShortlinkController(zapLog *zap.Logger, tracer trace.Tracer, client *shortlinkClient.ShortlinkClient) *ShortlinkController { controller := &ShortlinkController{ - log: log, + zapLog: zapLog, tracer: tracer, client: client, - authenticatedClient: shortlinkClient.NewAuthenticatedShortlinkClient(log, tracer, client), + authenticatedClient: shortlinkClient.NewAuthenticatedShortlinkClient(zapLog, tracer, client), } return controller diff --git a/pkg/observability/helpers.go b/pkg/observability/helpers.go index cfe49fb..8564ef1 100644 --- a/pkg/observability/helpers.go +++ b/pkg/observability/helpers.go @@ -3,23 +3,23 @@ package observability import ( "fmt" - "github.com/go-logr/logr" "github.com/pkg/errors" "go.opentelemetry.io/otel/trace" + "go.uber.org/zap" ) -func RecordError(span trace.Span, log *logr.Logger, err error, msg string, args ...any) error { +func RecordError(span trace.Span, zapLog *zap.SugaredLogger, err error, msg string, args ...any) error { message := fmt.Sprintf(msg, args...) span.AddEvent(message) - log.WithValues("traceID", span.SpanContext().TraceID()).Error(err, message) + zapLog.Errorw(msg, zap.Error(err)) err = errors.Wrap(err, message) span.RecordError(err) return err } -func RecordInfo(span trace.Span, log *logr.Logger, msg string, args ...any) { - log.WithValues("traceID", span.SpanContext().TraceID()).Info(fmt.Sprintf(msg, args...)) +func RecordInfo(span trace.Span, zapLog *zap.SugaredLogger, msg string, args ...any) { + zapLog.Infof(msg, args...) span.AddEvent(fmt.Sprintf(msg, args...)) } diff --git a/pkg/observability/opentelemetry.go b/pkg/observability/opentelemetry.go index 86e83c8..808b2f6 100644 --- a/pkg/observability/opentelemetry.go +++ b/pkg/observability/opentelemetry.go @@ -2,11 +2,13 @@ package observability import ( "context" + "fmt" "os" "strings" "github.com/MrAlias/flow" "github.com/pkg/errors" + "github.com/uptrace/opentelemetry-go-extra/otelzap" "go.opentelemetry.io/otel" "go.opentelemetry.io/otel/exporters/otlp/otlptrace" "go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp" @@ -15,10 +17,10 @@ import ( sdkTrace "go.opentelemetry.io/otel/sdk/trace" semconv "go.opentelemetry.io/otel/semconv/v1.4.0" "go.opentelemetry.io/otel/trace" + "go.uber.org/zap" ) func InitTracer(serviceName, serviceVersion string) (*sdkTrace.TracerProvider, trace.Tracer, error) { - otlpEndpoint, ok := os.LookupEnv("OTLP_ENDPOINT") otlpInsecure := os.Getenv("OTLP_INSECURE") @@ -80,3 +82,28 @@ func InitTracer(serviceName, serviceVersion string) (*sdkTrace.TracerProvider, t return traceProvider, trace, nil } + +func InitLogging(debug bool) (*zap.Logger, *otelzap.Logger, func()) { + var zapLog *zap.Logger + var err error + + if debug { + zapLog, err = zap.NewDevelopment() + } else { + zapLog, err = zap.NewProduction() + } + + if err != nil { + panic(fmt.Sprintf("Failed to initialize logger (%v)", err)) + } + + otelZap := otelzap.New(zapLog, + otelzap.WithTraceIDField(true), + otelzap.WithCaller(true), + otelzap.WithErrorStatusLevel(zap.ErrorLevel), + ) + + undo := otelzap.ReplaceGlobals(otelZap) + + return zapLog, otelZap, undo +} diff --git a/pkg/router/router.go b/pkg/router/router.go index 4482315..5108901 100644 --- a/pkg/router/router.go +++ b/pkg/router/router.go @@ -1,16 +1,15 @@ package router import ( - "fmt" "net/http" docs "github.com/cedi/urlshortener/docs" urlShortenerController "github.com/cedi/urlshortener/pkg/controller" + "go.uber.org/zap" "github.com/gin-gonic/contrib/secure" "github.com/gin-gonic/gin" - "github.com/go-logr/logr" "go.opentelemetry.io/contrib/instrumentation/github.com/gin-gonic/gin/otelgin" swaggerFiles "github.com/swaggo/files" @@ -33,7 +32,7 @@ import ( // @in header // @name Authorization -func NewGinGonicHTTPServer(bindAddr string, setupLog *logr.Logger, serviceName string) (*gin.Engine, *http.Server) { +func NewGinGonicHTTPServer(bindAddr string, zapLog *zap.Logger, serviceName string) (*gin.Engine, *http.Server) { router := gin.New() router.Use( otelgin.Middleware(serviceName), @@ -55,7 +54,10 @@ func NewGinGonicHTTPServer(bindAddr string, setupLog *logr.Logger, serviceName s //static path router.Static("assets", "./html/assets") - setupLog.Info(fmt.Sprintf("Starting gin-tonic router on binAddr: '%s'", bindAddr)) + zapLog.Sugar().Infow("Starting gin-tonic router", + zap.String("bindAddr", bindAddr), + ) + srv := &http.Server{ Addr: bindAddr, Handler: router, From 99e6cc927c11c5601b68d2126498d9e9111e3213 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Tue, 6 Jun 2023 12:18:10 +0000 Subject: [PATCH 2/2] Bump k8s.io/apimachinery from 0.26.2 to 0.27.2 Bumps [k8s.io/apimachinery](https://github.com/kubernetes/apimachinery) from 0.26.2 to 0.27.2. - [Commits](https://github.com/kubernetes/apimachinery/compare/v0.26.2...v0.27.2) --- updated-dependencies: - dependency-name: k8s.io/apimachinery dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] --- go.mod | 18 ++++++++---------- go.sum | 43 ++++++++++++++++--------------------------- 2 files changed, 24 insertions(+), 37 deletions(-) diff --git a/go.mod b/go.mod index 5cd3feb..b25b916 100644 --- a/go.mod +++ b/go.mod @@ -7,11 +7,13 @@ require ( github.com/gin-gonic/contrib v0.0.0-20221130124618-7e01895a63f2 github.com/gin-gonic/gin v1.9.0 github.com/go-logr/logr v1.2.4 + github.com/go-logr/zapr v1.2.3 github.com/pkg/errors v0.9.1 github.com/prometheus/client_golang v1.14.0 github.com/swaggo/files v1.0.1 github.com/swaggo/gin-swagger v1.5.3 github.com/swaggo/swag v1.8.10 + github.com/uptrace/opentelemetry-go-extra/otelzap v0.2.1 go.opentelemetry.io/contrib/instrumentation/github.com/gin-gonic/gin/otelgin v0.39.0 go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.42.0 go.opentelemetry.io/otel v1.16.0 @@ -19,9 +21,10 @@ require ( go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.15.1 go.opentelemetry.io/otel/sdk v1.15.1 go.opentelemetry.io/otel/trace v1.16.0 + go.uber.org/zap v1.24.0 golang.org/x/exp v0.0.0-20230304125523-9ff063c70017 k8s.io/api v0.26.2 - k8s.io/apimachinery v0.26.2 + k8s.io/apimachinery v0.27.2 k8s.io/client-go v0.26.2 sigs.k8s.io/controller-runtime v0.14.5 ) @@ -46,7 +49,6 @@ require ( github.com/fsnotify/fsnotify v1.6.0 // indirect github.com/gin-contrib/sse v0.1.0 // indirect github.com/go-logr/stdr v1.2.2 // indirect - github.com/go-logr/zapr v1.2.3 // indirect github.com/go-openapi/jsonpointer v0.19.6 // indirect github.com/go-openapi/jsonreference v0.20.2 // indirect github.com/go-openapi/spec v0.20.8 // indirect @@ -57,7 +59,7 @@ require ( github.com/goccy/go-json v0.10.0 // indirect github.com/gogo/protobuf v1.3.2 // indirect github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect - github.com/golang/protobuf v1.5.2 // indirect + github.com/golang/protobuf v1.5.3 // indirect github.com/google/gnostic v0.6.9 // indirect github.com/google/go-cmp v0.5.9 // indirect github.com/google/gofuzz v1.2.0 // indirect @@ -74,8 +76,6 @@ require ( github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect github.com/modern-go/reflect2 v1.0.2 // indirect github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect - github.com/onsi/ginkgo/v2 v2.6.1 // indirect - github.com/onsi/gomega v1.24.2 // indirect github.com/pelletier/go-toml/v2 v2.0.6 // indirect github.com/prometheus/client_model v0.3.0 // indirect github.com/prometheus/common v0.39.0 // indirect @@ -84,12 +84,10 @@ require ( github.com/twitchyliquid64/golang-asm v0.15.1 // indirect github.com/ugorji/go/codec v1.2.9 // indirect github.com/uptrace/opentelemetry-go-extra/otelutil v0.2.1 // indirect - github.com/uptrace/opentelemetry-go-extra/otelzap v0.2.1 // indirect go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.15.1 // indirect go.opentelemetry.io/proto/otlp v0.19.0 // indirect go.uber.org/atomic v1.11.0 // indirect go.uber.org/multierr v1.11.0 // indirect - go.uber.org/zap v1.24.0 // indirect golang.org/x/arch v0.0.0-20210923205945-b76863e36670 // indirect golang.org/x/crypto v0.6.0 // indirect golang.org/x/net v0.8.0 // indirect @@ -98,7 +96,7 @@ require ( golang.org/x/term v0.6.0 // indirect golang.org/x/text v0.8.0 // indirect golang.org/x/time v0.3.0 // indirect - golang.org/x/tools v0.6.0 // indirect + golang.org/x/tools v0.7.0 // indirect gomodules.xyz/jsonpatch/v2 v2.2.0 // indirect google.golang.org/appengine v1.6.7 // indirect google.golang.org/genproto v0.0.0-20230216225411-c8e22ba71e44 // indirect @@ -109,8 +107,8 @@ require ( gopkg.in/yaml.v3 v3.0.1 // indirect k8s.io/apiextensions-apiserver v0.26.1 // indirect k8s.io/component-base v0.26.1 // indirect - k8s.io/klog/v2 v2.90.0 // indirect - k8s.io/kube-openapi v0.0.0-20230217203603-ff9a8e8fa21d // indirect + k8s.io/klog/v2 v2.90.1 // indirect + k8s.io/kube-openapi v0.0.0-20230501164219-8b0f38b5fd1f // indirect k8s.io/utils v0.0.0-20230209194617-a36077c30491 // indirect sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd // indirect sigs.k8s.io/structured-merge-diff/v4 v4.2.3 // indirect diff --git a/go.sum b/go.sum index 3271fb7..b060484 100644 --- a/go.sum +++ b/go.sum @@ -160,6 +160,7 @@ github.com/go-playground/validator/v10 v10.10.0/go.mod h1:74x4gJWsvQexRdW8Pn3dXS github.com/go-playground/validator/v10 v10.11.2 h1:q3SHpufmypg+erIExEKUmsgmhDTyhcJ38oeKGACXohU= github.com/go-playground/validator/v10 v10.11.2/go.mod h1:NieE624vt4SCTJtD87arVLvdmjPAeV8BQlHtMnw9D7s= github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY= +github.com/go-task/slim-sprig v0.0.0-20210107165309-348f09dbbbc0 h1:p104kn46Q8WdvHunIJ9dAyjPVtrBPhSr3KT2yUst43I= github.com/goccy/go-json v0.9.7/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I= github.com/goccy/go-json v0.10.0 h1:mXKd9Qw4NuzShiRlOXKews24ufknHO7gx30lsDyokKA= github.com/goccy/go-json v0.10.0/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I= @@ -196,8 +197,9 @@ github.com/golang/protobuf v1.4.1/go.mod h1:U8fpvMrcmy5pZrNK1lt4xCsGvpyWQ/VVv6QD github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk= -github.com/golang/protobuf v1.5.2 h1:ROPKBNFfQgOUMifHyP+KYbvpjbdoFNs+aK7DXlji0Tw= github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= +github.com/golang/protobuf v1.5.3 h1:KhyjKVUg7Usr/dYsdSqoFveMYd5ko72D+zANwlG1mmg= +github.com/golang/protobuf v1.5.3/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= github.com/google/btree v0.0.0-20180813153112-4030bb1f1f0c/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ= github.com/google/btree v1.0.0/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ= github.com/google/gnostic v0.6.9 h1:ZK/5VhkoX835RikCHpSUJV9a+S3e1zLh59YnyWeBW+0= @@ -227,6 +229,7 @@ github.com/google/pprof v0.0.0-20200212024743-f11f1df84d12/go.mod h1:ZgVRPoUq/hf github.com/google/pprof v0.0.0-20200229191704-1ebb73c60ed3/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= github.com/google/pprof v0.0.0-20200430221834-fc25d7d30c6d/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= github.com/google/pprof v0.0.0-20200708004538-1a94d8640e99/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= +github.com/google/pprof v0.0.0-20210720184732-4bb14d4b1be1 h1:K6RDEckDVWvDI9JAJYCmNdQXq6neHJOYx3V6jnqNEec= github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI= github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/google/uuid v1.3.0 h1:t6JiXgmwXMjEs8VusXIJk2BXHsn+wx8BZdTaoZ5fu7I= @@ -298,10 +301,8 @@ github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822/go.mod h1:+n7T8m github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno= -github.com/onsi/ginkgo/v2 v2.6.1 h1:1xQPCjcqYw/J5LchOcp4/2q/jzJFjiAOc25chhnDw+Q= -github.com/onsi/ginkgo/v2 v2.6.1/go.mod h1:yjiuMwPokqY1XauOgju45q3sJt6VzQ/Fict1LFVcsAo= -github.com/onsi/gomega v1.24.2 h1:J/tulyYK6JwBldPViHJReihxxZ+22FHs0piGjQAvoUE= -github.com/onsi/gomega v1.24.2/go.mod h1:gs3J10IS7Z7r7eXRoNJIrNqU4ToQukCJhFtKrWgHWnk= +github.com/onsi/ginkgo/v2 v2.9.1 h1:zie5Ly042PD3bsCvsSOPvRnFwyo3rKe64TJlD6nu0mk= +github.com/onsi/gomega v1.27.4 h1:Z2AnStgsdSayCMDiCU42qIz+HLqEPcgiOCXjAU/w+8E= github.com/otiai10/copy v1.7.0/go.mod h1:rmRl6QPdJj6EiUqXQ/4Nn2lLXoNQjFCQbbNrxgc/t3U= github.com/otiai10/curr v0.0.0-20150429015615-9b4961190c95/go.mod h1:9qAhocn7zKJG+0mI8eUu6xqkFDYS2kb2saOteoSB3cE= github.com/otiai10/curr v1.0.0/go.mod h1:LskTG5wDwr8Rs+nNQ+1LlxRjAtTZZjtJW4rMXl6j4vs= @@ -372,7 +373,7 @@ github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/ github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU= github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4= -github.com/stretchr/testify v1.8.2 h1:+h33VjcLVPDHtOdpUCuF+7gSuG3yGIftsP1YvFihtJ8= +github.com/stretchr/testify v1.8.3 h1:RP3t2pwF7cMEbC1dqtB6poj3niw/9gnV4Cjg5oW5gtY= github.com/swaggo/files v0.0.0-20220728132757-551d4a08d97a/go.mod h1:lKJPbtWzJ9JhsTN1k1gZgleJWY/cqq0psdoMmaThG3w= github.com/swaggo/files v1.0.1 h1:J1bVJ4XHZNq0I46UU90611i9/YzdrF7x92oX1ig5IdE= github.com/swaggo/files v1.0.1/go.mod h1:0qXmMNH6sXNf+73t65aKeB+ApmgxdnkQzVTAj2uaMUg= @@ -408,14 +409,10 @@ go.opencensus.io v0.22.3/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= go.opencensus.io v0.22.4/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= go.opentelemetry.io/contrib/instrumentation/github.com/gin-gonic/gin/otelgin v0.39.0 h1:Z5u7efQA5B3/aa2riKHeorvROjmhhXOTRtP4nVtkIJA= go.opentelemetry.io/contrib/instrumentation/github.com/gin-gonic/gin/otelgin v0.39.0/go.mod h1:dbx2pPD/jZWsnCz7ogHKY2mmHHnRU4bkjOVsw1V8x/o= -go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.40.0 h1:lE9EJyw3/JhrjWH/hEy9FptnalDQgj7vpbgC2KCCCxE= -go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.40.0/go.mod h1:pcQ3MM3SWvrA71U4GDqv9UFDJ3HQsW7y5ZO3tDTlUdI= go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.42.0 h1:pginetY7+onl4qN1vl0xW/V/v6OBZ0vVdH+esuJgvmM= go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.42.0/go.mod h1:XiYsayHc36K3EByOO6nbAXnAWbrUxdjUROCEeeROOH8= go.opentelemetry.io/contrib/propagators/b3 v1.14.0 h1:0SBc35DESy/YXShxFtu3634OwcEWJoGzSA8Hx/NbOo8= go.opentelemetry.io/otel v1.7.0/go.mod h1:5BdUoMIz5WEs0vt0CUEMtSSaTSHBBVwrhnz7+nrD5xk= -go.opentelemetry.io/otel v1.15.1 h1:3Iwq3lfRByPaws0f6bU3naAqOR1n5IeDWd9390kWHa8= -go.opentelemetry.io/otel v1.15.1/go.mod h1:mHHGEHVDLal6YrKMmk9LqC4a3sF5g+fHfrttQIB1NTc= go.opentelemetry.io/otel v1.16.0 h1:Z7GVAX/UkAXPKsy94IU+i6thsQS4nb7LviLpnaNeW8s= go.opentelemetry.io/otel v1.16.0/go.mod h1:vl0h9NUa1D5s1nv3A5vZOYWn8av4K8Ml6JDeHrT/bx4= go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.15.1 h1:XYDQtNzdb2T4uM1pku2m76eSMDJgqhJ+6KzkqgQBALc= @@ -424,31 +421,23 @@ go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.15.1 h1:tyoeaUh8REKay72DVYs go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.15.1/go.mod h1:HUSnrjQQ19KX9ECjpQxufsF+3ioD3zISPMlauTPZu2g= go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.15.1 h1:pnJfHmVcCEBcH5lkM+npJF8cTAjV/d+9cXVNCs5P/ao= go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.15.1/go.mod h1:cC3Eu2V56zXY09YlijmqDhOUnL2jVL6KKJg4PGh++dU= -go.opentelemetry.io/otel/metric v0.37.0 h1:pHDQuLQOZwYD+Km0eb657A25NaRzy0a+eLyKfDXedEs= -go.opentelemetry.io/otel/metric v0.37.0/go.mod h1:DmdaHfGt54iV6UKxsV9slj2bBRJcKC1B1uvDLIioc1s= go.opentelemetry.io/otel/metric v1.16.0 h1:RbrpwVG1Hfv85LgnZ7+txXioPDoh6EdbZHo26Q3hqOo= go.opentelemetry.io/otel/metric v1.16.0/go.mod h1:QE47cpOmkwipPiefDwo2wDzwJrlfxxNYodqc4xnGCo4= go.opentelemetry.io/otel/sdk v1.7.0/go.mod h1:uTEOTwaqIVuTGiJN7ii13Ibp75wJmYUDe374q6cZwUU= go.opentelemetry.io/otel/sdk v1.15.1 h1:5FKR+skgpzvhPQHIEfcwMYjCBr14LWzs3uSqKiQzETI= go.opentelemetry.io/otel/sdk v1.15.1/go.mod h1:8rVtxQfrbmbHKfqzpQkT5EzZMcbMBwTzNAggbEAM0KA= go.opentelemetry.io/otel/trace v1.7.0/go.mod h1:fzLSB9nqR2eXzxPXb2JW9IKE+ScyXA48yyE4TNvoHqU= -go.opentelemetry.io/otel/trace v1.15.1 h1:uXLo6iHJEzDfrNC0L0mNjItIp06SyaBQxu5t3xMlngY= -go.opentelemetry.io/otel/trace v1.15.1/go.mod h1:IWdQG/5N1x7f6YUlmdLeJvH9yxtuJAfc4VW5Agv9r/8= go.opentelemetry.io/otel/trace v1.16.0 h1:8JRpaObFoW0pxuVPapkgH8UhHQj+bJW8jJsCZEu5MQs= go.opentelemetry.io/otel/trace v1.16.0/go.mod h1:Yt9vYq1SdNz3xdjZZK7wcXv1qv2pwLkqr2QVwea0ef0= go.opentelemetry.io/proto/otlp v0.7.0/go.mod h1:PqfVotwruBrMGOCsRd/89rSnXhoiJIqeYNgFYFoEGnI= go.opentelemetry.io/proto/otlp v0.19.0 h1:IVN6GR+mhC4s5yfcTbmzHYODqvWAp3ZedA2SJPI1Nnw= go.opentelemetry.io/proto/otlp v0.19.0/go.mod h1:H7XAot3MsfNsj7EXtrA2q5xSNQ10UqI405h3+duxN4U= go.uber.org/atomic v1.7.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= -go.uber.org/atomic v1.10.0 h1:9qC72Qh0+3MqyJbAn8YU5xVq1frD8bn3JtD2oXtafVQ= -go.uber.org/atomic v1.10.0/go.mod h1:LUxbIzbOniOlMKjJjyPfpl4v+PKK2cNJn91OQbhoJI0= go.uber.org/atomic v1.11.0 h1:ZvwS0R+56ePWxUNi+Atn9dWONBPp/AUETXlHW0DxSjE= go.uber.org/atomic v1.11.0/go.mod h1:LUxbIzbOniOlMKjJjyPfpl4v+PKK2cNJn91OQbhoJI0= go.uber.org/goleak v1.1.10/go.mod h1:8a7PlsEVH3e/a/GLqe5IIrQx6GzcnRmZEufDUTk4A7A= go.uber.org/goleak v1.2.0 h1:xqgm/S+aQvhWFTtR0XK3Jvg7z8kGV8P4X14IzwN3Eqk= go.uber.org/multierr v1.6.0/go.mod h1:cdWPpRnG4AhwMwsgIHip0KRBQjJy5kYEpYjJxpXp9iU= -go.uber.org/multierr v1.9.0 h1:7fIwc/ZtS0q++VgcfqFDxSBZVv/Xo49/SYnDFupUwlI= -go.uber.org/multierr v1.9.0/go.mod h1:X2jQV1h+kxSjClGpnseKVIxpmcjrj7MNnI0bnlfKTVQ= go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0= go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y= go.uber.org/zap v1.19.0/go.mod h1:xg/QME4nWcxGxrpdeYfq7UvYrLh66cuVKdrbD1XF/NI= @@ -500,7 +489,7 @@ golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4= -golang.org/x/mod v0.8.0 h1:LUYupSeNrTNCGzR/hVBk2NHZO4hXcVaW1k4Qx7rjPx8= +golang.org/x/mod v0.9.0 h1:KENHtAZL2y3NLMYZeHY9DW8HW8V+kQyJsY/V9JlKvCs= golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20181114220301-adae6a3d119a/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= @@ -681,8 +670,8 @@ golang.org/x/tools v0.0.0-20200825202427-b303f430e36d/go.mod h1:njjCfa9FT2d7l9Bc golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= golang.org/x/tools v0.1.7/go.mod h1:LGqMHiF4EqQNHR1JncWGqT5BVaXmza+X+BDGol+dOxo= golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc= -golang.org/x/tools v0.6.0 h1:BOw41kyTf3PuCW1pVQf8+Cyg8pMlkYB1oo9iJ6D/lKM= -golang.org/x/tools v0.6.0/go.mod h1:Xwgl3UAJ/d3gWutnCtw505GrjyAbvKui8lOU390QaIU= +golang.org/x/tools v0.7.0 h1:W4OVu8VVOaIO0yzWMNdepAulS7YfoS3Zabrm8DOXXU4= +golang.org/x/tools v0.7.0/go.mod h1:4pg6aUX35JBAogB10C9AtvVL+qowtN4pT3CGSQex14s= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= @@ -817,16 +806,16 @@ k8s.io/api v0.26.2 h1:dM3cinp3PGB6asOySalOZxEG4CZ0IAdJsrYZXE/ovGQ= k8s.io/api v0.26.2/go.mod h1:1kjMQsFE+QHPfskEcVNgL3+Hp88B80uj0QtSOlj8itU= k8s.io/apiextensions-apiserver v0.26.1 h1:cB8h1SRk6e/+i3NOrQgSFij1B2S0Y0wDoNl66bn8RMI= k8s.io/apiextensions-apiserver v0.26.1/go.mod h1:AptjOSXDGuE0JICx/Em15PaoO7buLwTs0dGleIHixSM= -k8s.io/apimachinery v0.26.2 h1:da1u3D5wfR5u2RpLhE/ZtZS2P7QvDgLZTi9wrNZl/tQ= -k8s.io/apimachinery v0.26.2/go.mod h1:ats7nN1LExKHvJ9TmwootT00Yz05MuYqPXEXaVeOy5I= +k8s.io/apimachinery v0.27.2 h1:vBjGaKKieaIreI+oQwELalVG4d8f3YAMNpWLzDXkxeg= +k8s.io/apimachinery v0.27.2/go.mod h1:XNfZ6xklnMCOGGFNqXG7bUrQCoR04dh/E7FprV6pb+E= k8s.io/client-go v0.26.2 h1:s1WkVujHX3kTp4Zn4yGNFK+dlDXy1bAAkIl+cFAiuYI= k8s.io/client-go v0.26.2/go.mod h1:u5EjOuSyBa09yqqyY7m3abZeovO/7D/WehVVlZ2qcqU= k8s.io/component-base v0.26.1 h1:4ahudpeQXHZL5kko+iDHqLj/FSGAEUnSVO0EBbgDd+4= k8s.io/component-base v0.26.1/go.mod h1:VHrLR0b58oC035w6YQiBSbtsf0ThuSwXP+p5dD/kAWU= -k8s.io/klog/v2 v2.90.0 h1:VkTxIV/FjRXn1fgNNcKGM8cfmL1Z33ZjXRTVxKCoF5M= -k8s.io/klog/v2 v2.90.0/go.mod h1:y1WjHnz7Dj687irZUWR/WLkLc5N1YHtjLdmgWjndZn0= -k8s.io/kube-openapi v0.0.0-20230217203603-ff9a8e8fa21d h1:oFDpQ7FfzinCtrFOl4izwOWsdTprlS2A9IXBENMW0UA= -k8s.io/kube-openapi v0.0.0-20230217203603-ff9a8e8fa21d/go.mod h1:/BYxry62FuDzmI+i9B+X2pqfySRmSOW2ARmj5Zbqhj0= +k8s.io/klog/v2 v2.90.1 h1:m4bYOKall2MmOiRaR1J+We67Do7vm9KiQVlT96lnHUw= +k8s.io/klog/v2 v2.90.1/go.mod h1:y1WjHnz7Dj687irZUWR/WLkLc5N1YHtjLdmgWjndZn0= +k8s.io/kube-openapi v0.0.0-20230501164219-8b0f38b5fd1f h1:2kWPakN3i/k81b0gvD5C5FJ2kxm1WrQFanWchyKuqGg= +k8s.io/kube-openapi v0.0.0-20230501164219-8b0f38b5fd1f/go.mod h1:byini6yhqGC14c3ebc/QwanvYwhuMWF6yz2F8uwW8eg= k8s.io/utils v0.0.0-20230209194617-a36077c30491 h1:r0BAOLElQnnFhE/ApUsg3iHdVYYPBjNSSOMowRZxxsY= k8s.io/utils v0.0.0-20230209194617-a36077c30491/go.mod h1:OLgZIPagt7ERELqWJFomSt595RzquPNLL48iOWgYOg0= rsc.io/binaryregexp v0.2.0/go.mod h1:qTv7/COck+e2FymRvadv62gMdZztPaShugOCi3I+8D8=