package gclient import ( "k8s.io/apimachinery/pkg/runtime" "k8s.io/client-go/kubernetes/scheme" "k8s.io/client-go/rest" "sigs.k8s.io/controller-runtime/pkg/client" mcsv1alpha1 "sigs.k8s.io/mcs-api/pkg/apis/v1alpha1" clusterv1alpha1 "github.com/karmada-io/karmada/pkg/apis/cluster/v1alpha1" policyv1alpha1 "github.com/karmada-io/karmada/pkg/apis/policy/v1alpha1" workv1alpha1 "github.com/karmada-io/karmada/pkg/apis/work/v1alpha1" ) // aggregatedScheme aggregates Kubernetes and extended schemes. var aggregatedScheme = runtime.NewScheme() func init() { var _ = scheme.AddToScheme(aggregatedScheme) // add Kubernetes schemes var _ = clusterv1alpha1.AddToScheme(aggregatedScheme) // add cluster schemes var _ = policyv1alpha1.AddToScheme(aggregatedScheme) // add propagation schemes var _ = workv1alpha1.AddToScheme(aggregatedScheme) // add work schemes var _ = mcsv1alpha1.AddToScheme(aggregatedScheme) // add mcs-api schemes } // NewSchema returns a singleton schema set which aggregated Kubernetes's schemes and extended schemes. func NewSchema() *runtime.Scheme { return aggregatedScheme } // NewForConfig creates a new client for the given config. func NewForConfig(config *rest.Config) (client.Client, error) { return client.New(config, client.Options{ Scheme: aggregatedScheme, }) } // NewForConfigOrDie creates a new client for the given config and // panics if there is an error in the config. func NewForConfigOrDie(config *rest.Config) client.Client { c, err := NewForConfig(config) if err != nil { panic(err) } return c }