1/*
2Copyright The Kubernetes Authors.
3
4Licensed under the Apache License, Version 2.0 (the "License");
5you may not use this file except in compliance with the License.
6You may obtain a copy of the License at
7
8    http://www.apache.org/licenses/LICENSE-2.0
9
10Unless required by applicable law or agreed to in writing, software
11distributed under the License is distributed on an "AS IS" BASIS,
12WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13See the License for the specific language governing permissions and
14limitations under the License.
15*/
16
17// Code generated by lister-gen. DO NOT EDIT.
18
19package v1
20
21import (
22	v1 "k8s.io/api/apps/v1"
23	"k8s.io/apimachinery/pkg/api/errors"
24	"k8s.io/apimachinery/pkg/labels"
25	"k8s.io/client-go/tools/cache"
26)
27
28// DaemonSetLister helps list DaemonSets.
29// All objects returned here must be treated as read-only.
30type DaemonSetLister interface {
31	// List lists all DaemonSets in the indexer.
32	// Objects returned here must be treated as read-only.
33	List(selector labels.Selector) (ret []*v1.DaemonSet, err error)
34	// DaemonSets returns an object that can list and get DaemonSets.
35	DaemonSets(namespace string) DaemonSetNamespaceLister
36	DaemonSetListerExpansion
37}
38
39// daemonSetLister implements the DaemonSetLister interface.
40type daemonSetLister struct {
41	indexer cache.Indexer
42}
43
44// NewDaemonSetLister returns a new DaemonSetLister.
45func NewDaemonSetLister(indexer cache.Indexer) DaemonSetLister {
46	return &daemonSetLister{indexer: indexer}
47}
48
49// List lists all DaemonSets in the indexer.
50func (s *daemonSetLister) List(selector labels.Selector) (ret []*v1.DaemonSet, err error) {
51	err = cache.ListAll(s.indexer, selector, func(m interface{}) {
52		ret = append(ret, m.(*v1.DaemonSet))
53	})
54	return ret, err
55}
56
57// DaemonSets returns an object that can list and get DaemonSets.
58func (s *daemonSetLister) DaemonSets(namespace string) DaemonSetNamespaceLister {
59	return daemonSetNamespaceLister{indexer: s.indexer, namespace: namespace}
60}
61
62// DaemonSetNamespaceLister helps list and get DaemonSets.
63// All objects returned here must be treated as read-only.
64type DaemonSetNamespaceLister interface {
65	// List lists all DaemonSets in the indexer for a given namespace.
66	// Objects returned here must be treated as read-only.
67	List(selector labels.Selector) (ret []*v1.DaemonSet, err error)
68	// Get retrieves the DaemonSet from the indexer for a given namespace and name.
69	// Objects returned here must be treated as read-only.
70	Get(name string) (*v1.DaemonSet, error)
71	DaemonSetNamespaceListerExpansion
72}
73
74// daemonSetNamespaceLister implements the DaemonSetNamespaceLister
75// interface.
76type daemonSetNamespaceLister struct {
77	indexer   cache.Indexer
78	namespace string
79}
80
81// List lists all DaemonSets in the indexer for a given namespace.
82func (s daemonSetNamespaceLister) List(selector labels.Selector) (ret []*v1.DaemonSet, err error) {
83	err = cache.ListAllByNamespace(s.indexer, s.namespace, selector, func(m interface{}) {
84		ret = append(ret, m.(*v1.DaemonSet))
85	})
86	return ret, err
87}
88
89// Get retrieves the DaemonSet from the indexer for a given namespace and name.
90func (s daemonSetNamespaceLister) Get(name string) (*v1.DaemonSet, error) {
91	obj, exists, err := s.indexer.GetByKey(s.namespace + "/" + name)
92	if err != nil {
93		return nil, err
94	}
95	if !exists {
96		return nil, errors.NewNotFound(v1.Resource("daemonset"), name)
97	}
98	return obj.(*v1.DaemonSet), nil
99}
100