package helper import ( "k8s.io/apimachinery/pkg/api/errors" "k8s.io/apimachinery/pkg/api/meta" "k8s.io/apimachinery/pkg/apis/meta/v1/unstructured" "k8s.io/apimachinery/pkg/runtime" "k8s.io/klog/v2" "github.com/karmada-io/karmada/pkg/util/informermanager" "github.com/karmada-io/karmada/pkg/util/informermanager/keys" "github.com/karmada-io/karmada/pkg/util/restmapper" ) // GetObjectFromCache gets full object information from cache by key in worker queue. func GetObjectFromCache(restMapper meta.RESTMapper, manager informermanager.MultiClusterInformerManager, fedKey keys.FederatedKey) (*unstructured.Unstructured, error) { gvr, err := restmapper.GetGroupVersionResource(restMapper, fedKey.GroupVersionKind()) if err != nil { klog.Errorf("Failed to get GVR from GVK %s. Error: %v", fedKey.GroupVersionKind(), err) return nil, err } singleClusterManager := manager.GetSingleClusterManager(fedKey.Cluster) if singleClusterManager == nil { return nil, nil } var obj runtime.Object lister := singleClusterManager.Lister(gvr) obj, err = lister.Get(fedKey.NamespaceKey()) if err != nil { if errors.IsNotFound(err) { return nil, err } // print logs only for real error. klog.Errorf("Failed to get obj %s. error: %v.", fedKey.String(), err) return nil, err } return obj.(*unstructured.Unstructured), nil }