pkg/informers/externalversions/networking/v1beta1/workloadentry.gen.go (55 lines of code) (raw):

// 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 informer-gen. DO NOT EDIT. package v1beta1 import ( "context" time "time" networkingv1beta1 "istio.io/client-go/pkg/apis/networking/v1beta1" versioned "istio.io/client-go/pkg/clientset/versioned" internalinterfaces "istio.io/client-go/pkg/informers/externalversions/internalinterfaces" v1beta1 "istio.io/client-go/pkg/listers/networking/v1beta1" v1 "k8s.io/apimachinery/pkg/apis/meta/v1" runtime "k8s.io/apimachinery/pkg/runtime" watch "k8s.io/apimachinery/pkg/watch" cache "k8s.io/client-go/tools/cache" ) // WorkloadEntryInformer provides access to a shared informer and lister for // WorkloadEntries. type WorkloadEntryInformer interface { Informer() cache.SharedIndexInformer Lister() v1beta1.WorkloadEntryLister } type workloadEntryInformer struct { factory internalinterfaces.SharedInformerFactory tweakListOptions internalinterfaces.TweakListOptionsFunc namespace string } // NewWorkloadEntryInformer constructs a new informer for WorkloadEntry type. // Always prefer using an informer factory to get a shared informer instead of getting an independent // one. This reduces memory footprint and number of connections to the server. func NewWorkloadEntryInformer(client versioned.Interface, namespace string, resyncPeriod time.Duration, indexers cache.Indexers) cache.SharedIndexInformer { return NewFilteredWorkloadEntryInformer(client, namespace, resyncPeriod, indexers, nil) } // NewFilteredWorkloadEntryInformer constructs a new informer for WorkloadEntry type. // Always prefer using an informer factory to get a shared informer instead of getting an independent // one. This reduces memory footprint and number of connections to the server. func NewFilteredWorkloadEntryInformer(client versioned.Interface, namespace string, resyncPeriod time.Duration, indexers cache.Indexers, tweakListOptions internalinterfaces.TweakListOptionsFunc) cache.SharedIndexInformer { return cache.NewSharedIndexInformer( &cache.ListWatch{ ListFunc: func(options v1.ListOptions) (runtime.Object, error) { if tweakListOptions != nil { tweakListOptions(&options) } return client.NetworkingV1beta1().WorkloadEntries(namespace).List(context.TODO(), options) }, WatchFunc: func(options v1.ListOptions) (watch.Interface, error) { if tweakListOptions != nil { tweakListOptions(&options) } return client.NetworkingV1beta1().WorkloadEntries(namespace).Watch(context.TODO(), options) }, }, &networkingv1beta1.WorkloadEntry{}, resyncPeriod, indexers, ) } func (f *workloadEntryInformer) defaultInformer(client versioned.Interface, resyncPeriod time.Duration) cache.SharedIndexInformer { return NewFilteredWorkloadEntryInformer(client, f.namespace, resyncPeriod, cache.Indexers{cache.NamespaceIndex: cache.MetaNamespaceIndexFunc}, f.tweakListOptions) } func (f *workloadEntryInformer) Informer() cache.SharedIndexInformer { return f.factory.InformerFor(&networkingv1beta1.WorkloadEntry{}, f.defaultInformer) } func (f *workloadEntryInformer) Lister() v1beta1.WorkloadEntryLister { return v1beta1.NewWorkloadEntryLister(f.Informer().GetIndexer()) }