// Copyright Istio Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // Code generated by client-gen. DO NOT EDIT. package versioned import ( "fmt" configv1alpha2 "istio.io/client-go/pkg/clientset/versioned/typed/config/v1alpha2" networkingv1alpha3 "istio.io/client-go/pkg/clientset/versioned/typed/networking/v1alpha3" networkingv1beta1 "istio.io/client-go/pkg/clientset/versioned/typed/networking/v1beta1" rbacv1alpha1 "istio.io/client-go/pkg/clientset/versioned/typed/rbac/v1alpha1" securityv1beta1 "istio.io/client-go/pkg/clientset/versioned/typed/security/v1beta1" discovery "k8s.io/client-go/discovery" rest "k8s.io/client-go/rest" flowcontrol "k8s.io/client-go/util/flowcontrol" ) type Interface interface { Discovery() discovery.DiscoveryInterface ConfigV1alpha2() configv1alpha2.ConfigV1alpha2Interface NetworkingV1alpha3() networkingv1alpha3.NetworkingV1alpha3Interface NetworkingV1beta1() networkingv1beta1.NetworkingV1beta1Interface RbacV1alpha1() rbacv1alpha1.RbacV1alpha1Interface SecurityV1beta1() securityv1beta1.SecurityV1beta1Interface } // Clientset contains the clients for groups. Each group has exactly one // version included in a Clientset. type Clientset struct { *discovery.DiscoveryClient configV1alpha2 *configv1alpha2.ConfigV1alpha2Client networkingV1alpha3 *networkingv1alpha3.NetworkingV1alpha3Client networkingV1beta1 *networkingv1beta1.NetworkingV1beta1Client rbacV1alpha1 *rbacv1alpha1.RbacV1alpha1Client securityV1beta1 *securityv1beta1.SecurityV1beta1Client } // ConfigV1alpha2 retrieves the ConfigV1alpha2Client func (c *Clientset) ConfigV1alpha2() configv1alpha2.ConfigV1alpha2Interface { return c.configV1alpha2 } // NetworkingV1alpha3 retrieves the NetworkingV1alpha3Client func (c *Clientset) NetworkingV1alpha3() networkingv1alpha3.NetworkingV1alpha3Interface { return c.networkingV1alpha3 } // NetworkingV1beta1 retrieves the NetworkingV1beta1Client func (c *Clientset) NetworkingV1beta1() networkingv1beta1.NetworkingV1beta1Interface { return c.networkingV1beta1 } // RbacV1alpha1 retrieves the RbacV1alpha1Client func (c *Clientset) RbacV1alpha1() rbacv1alpha1.RbacV1alpha1Interface { return c.rbacV1alpha1 } // SecurityV1beta1 retrieves the SecurityV1beta1Client func (c *Clientset) SecurityV1beta1() securityv1beta1.SecurityV1beta1Interface { return c.securityV1beta1 } // Discovery retrieves the DiscoveryClient func (c *Clientset) Discovery() discovery.DiscoveryInterface { if c == nil { return nil } return c.DiscoveryClient } // NewForConfig creates a new Clientset for the given config. // If config's RateLimiter is not set and QPS and Burst are acceptable, // NewForConfig will generate a rate-limiter in configShallowCopy. func NewForConfig(c *rest.Config) (*Clientset, error) { configShallowCopy := *c if configShallowCopy.RateLimiter == nil && configShallowCopy.QPS > 0 { if configShallowCopy.Burst <= 0 { return nil, fmt.Errorf("burst is required to be greater than 0 when RateLimiter is not set and QPS is set to greater than 0") } configShallowCopy.RateLimiter = flowcontrol.NewTokenBucketRateLimiter(configShallowCopy.QPS, configShallowCopy.Burst) } var cs Clientset var err error cs.configV1alpha2, err = configv1alpha2.NewForConfig(&configShallowCopy) if err != nil { return nil, err } cs.networkingV1alpha3, err = networkingv1alpha3.NewForConfig(&configShallowCopy) if err != nil { return nil, err } cs.networkingV1beta1, err = networkingv1beta1.NewForConfig(&configShallowCopy) if err != nil { return nil, err } cs.rbacV1alpha1, err = rbacv1alpha1.NewForConfig(&configShallowCopy) if err != nil { return nil, err } cs.securityV1beta1, err = securityv1beta1.NewForConfig(&configShallowCopy) if err != nil { return nil, err } cs.DiscoveryClient, err = discovery.NewDiscoveryClientForConfig(&configShallowCopy) if err != nil { return nil, err } return &cs, nil } // NewForConfigOrDie creates a new Clientset for the given config and // panics if there is an error in the config. func NewForConfigOrDie(c *rest.Config) *Clientset { var cs Clientset cs.configV1alpha2 = configv1alpha2.NewForConfigOrDie(c) cs.networkingV1alpha3 = networkingv1alpha3.NewForConfigOrDie(c) cs.networkingV1beta1 = networkingv1beta1.NewForConfigOrDie(c) cs.rbacV1alpha1 = rbacv1alpha1.NewForConfigOrDie(c) cs.securityV1beta1 = securityv1beta1.NewForConfigOrDie(c) cs.DiscoveryClient = discovery.NewDiscoveryClientForConfigOrDie(c) return &cs } // New creates a new Clientset for the given RESTClient. func New(c rest.Interface) *Clientset { var cs Clientset cs.configV1alpha2 = configv1alpha2.New(c) cs.networkingV1alpha3 = networkingv1alpha3.New(c) cs.networkingV1beta1 = networkingv1beta1.New(c) cs.rbacV1alpha1 = rbacv1alpha1.New(c) cs.securityV1beta1 = securityv1beta1.New(c) cs.DiscoveryClient = discovery.NewDiscoveryClient(c) return &cs }