aboutsummaryrefslogtreecommitdiff
path: root/plugin/kubernetes/controller.go
diff options
context:
space:
mode:
Diffstat (limited to 'plugin/kubernetes/controller.go')
-rw-r--r--plugin/kubernetes/controller.go33
1 files changed, 18 insertions, 15 deletions
diff --git a/plugin/kubernetes/controller.go b/plugin/kubernetes/controller.go
index 7155c320e..f3dbff454 100644
--- a/plugin/kubernetes/controller.go
+++ b/plugin/kubernetes/controller.go
@@ -39,7 +39,7 @@ type dnsController interface {
EpIndexReverse(string) []*object.Endpoints
GetNodeByName(context.Context, string) (*api.Node, error)
- GetNamespaceByName(string) (*api.Namespace, error)
+ GetNamespaceByName(string) (*object.Namespace, error)
Run()
HasSynced() bool
@@ -150,14 +150,16 @@ func newdnsController(ctx context.Context, kubeClient kubernetes.Interface, opts
dns.epLock.Unlock()
}
- dns.nsLister, dns.nsController = cache.NewInformer(
+ dns.nsLister, dns.nsController = object.NewIndexerInformer(
&cache.ListWatch{
ListFunc: namespaceListFunc(ctx, dns.client, dns.namespaceSelector),
WatchFunc: namespaceWatchFunc(ctx, dns.client, dns.namespaceSelector),
},
&api.Namespace{},
- defaultResyncPeriod,
- cache.ResourceEventHandlerFuncs{})
+ cache.ResourceEventHandlerFuncs{},
+ cache.Indexers{},
+ object.DefaultProcessor(object.ToNamespace, nil),
+ )
return &dns
}
@@ -539,18 +541,19 @@ func (dns *dnsControl) GetNodeByName(ctx context.Context, name string) (*api.Nod
}
// GetNamespaceByName returns the namespace by name. If nothing is found an error is returned.
-func (dns *dnsControl) GetNamespaceByName(name string) (*api.Namespace, error) {
- os := dns.nsLister.List()
- for _, o := range os {
- ns, ok := o.(*api.Namespace)
- if !ok {
- continue
- }
- if name == ns.ObjectMeta.Name {
- return ns, nil
- }
+func (dns *dnsControl) GetNamespaceByName(name string) (*object.Namespace, error) {
+ o, exists, err := dns.nsLister.GetByKey(name)
+ if err != nil {
+ return nil, err
+ }
+ if !exists {
+ return nil, fmt.Errorf("namespace not found")
+ }
+ ns, ok := o.(*object.Namespace)
+ if !ok {
+ return nil, fmt.Errorf("found key but not namespace")
}
- return nil, fmt.Errorf("namespace not found")
+ return ns, nil
}
func (dns *dnsControl) Add(obj interface{}) { dns.updateModified() }