// Code generated by informer-gen. DO NOT EDIT.

package v1alpha1

import (
	"context"
	time "time"

	ensurancev1alpha1 "github.com/gocrane/api/ensurance/v1alpha1"
	versioned "github.com/gocrane/api/pkg/generated/clientset/versioned"
	internalinterfaces "github.com/gocrane/api/pkg/generated/informers/externalversions/internalinterfaces"
	v1alpha1 "github.com/gocrane/api/pkg/generated/listers/ensurance/v1alpha1"
	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"
)

// NodeQOSInformer provides access to a shared informer and lister for
// NodeQOSs.
type NodeQOSInformer interface {
	Informer() cache.SharedIndexInformer
	Lister() v1alpha1.NodeQOSLister
}

type nodeQOSInformer struct {
	factory          internalinterfaces.SharedInformerFactory
	tweakListOptions internalinterfaces.TweakListOptionsFunc
}

// NewNodeQOSInformer constructs a new informer for NodeQOS 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 NewNodeQOSInformer(client versioned.Interface, resyncPeriod time.Duration, indexers cache.Indexers) cache.SharedIndexInformer {
	return NewFilteredNodeQOSInformer(client, resyncPeriod, indexers, nil)
}

// NewFilteredNodeQOSInformer constructs a new informer for NodeQOS 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 NewFilteredNodeQOSInformer(client versioned.Interface, 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.EnsuranceV1alpha1().NodeQOSs().List(context.TODO(), options)
			},
			WatchFunc: func(options v1.ListOptions) (watch.Interface, error) {
				if tweakListOptions != nil {
					tweakListOptions(&options)
				}
				return client.EnsuranceV1alpha1().NodeQOSs().Watch(context.TODO(), options)
			},
		},
		&ensurancev1alpha1.NodeQOS{},
		resyncPeriod,
		indexers,
	)
}

func (f *nodeQOSInformer) defaultInformer(client versioned.Interface, resyncPeriod time.Duration) cache.SharedIndexInformer {
	return NewFilteredNodeQOSInformer(client, resyncPeriod, cache.Indexers{cache.NamespaceIndex: cache.MetaNamespaceIndexFunc}, f.tweakListOptions)
}

func (f *nodeQOSInformer) Informer() cache.SharedIndexInformer {
	return f.factory.InformerFor(&ensurancev1alpha1.NodeQOS{}, f.defaultInformer)
}

func (f *nodeQOSInformer) Lister() v1alpha1.NodeQOSLister {
	return v1alpha1.NewNodeQOSLister(f.Informer().GetIndexer())
}
