From c2dc44deb99d21320f3d6f4c58777a87c6d0de5b Mon Sep 17 00:00:00 2001 From: Austin Abro Date: Tue, 14 Jan 2025 14:59:30 +0000 Subject: [PATCH] use dynamic rest mapper Signed-off-by: Austin Abro --- pkg/kube/client.go | 11 ++++++++++- pkg/kube/factory.go | 4 ++++ 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/pkg/kube/client.go b/pkg/kube/client.go index daa484b69..b607ea3ef 100644 --- a/pkg/kube/client.go +++ b/pkg/kube/client.go @@ -38,6 +38,7 @@ import ( apierrors "k8s.io/apimachinery/pkg/api/errors" "k8s.io/apimachinery/pkg/runtime" "sigs.k8s.io/cli-utils/pkg/kstatus/watcher" + "sigs.k8s.io/controller-runtime/pkg/client/apiutil" multierror "github.com/hashicorp/go-multierror" "k8s.io/apimachinery/pkg/api/meta" @@ -107,11 +108,19 @@ func init() { } func getStatusWatcher(factory Factory) (watcher.StatusWatcher, error) { + cfg, err := factory.ToRESTConfig() + if err != nil { + return nil, err + } dynamicClient, err := factory.DynamicClient() if err != nil { return nil, err } - restMapper, err := factory.ToRESTMapper() + httpClient, err := rest.HTTPClientFor(cfg) + if err != nil { + return nil, err + } + restMapper, err := apiutil.NewDynamicRESTMapper(cfg, httpClient) if err != nil { return nil, err } diff --git a/pkg/kube/factory.go b/pkg/kube/factory.go index 013cd7b73..7f21c85c6 100644 --- a/pkg/kube/factory.go +++ b/pkg/kube/factory.go @@ -21,6 +21,7 @@ import ( "k8s.io/cli-runtime/pkg/resource" "k8s.io/client-go/dynamic" "k8s.io/client-go/kubernetes" + "k8s.io/client-go/rest" "k8s.io/client-go/tools/clientcmd" "k8s.io/kubectl/pkg/validation" ) @@ -37,6 +38,9 @@ type Factory interface { // ToRESTMapper returns a restmapper ToRESTMapper() (meta.RESTMapper, error) + // ToRESTConfig returns restconfig + ToRESTConfig() (*rest.Config, error) + // ToRawKubeConfigLoader return kubeconfig loader as-is ToRawKubeConfigLoader() clientcmd.ClientConfig