diff options
author | 2017-08-09 04:06:48 -0700 | |
---|---|---|
committer | 2017-08-09 04:06:48 -0700 | |
commit | b8e2c476a5535a35daa54ef4e13e627ffa5cb912 (patch) | |
tree | b71397a19b466fd241306b50e184648dbf66291c /middleware/kubernetes/autopath.go | |
parent | b46b9880bd606fd2d0acaccf7d1915a8803bc81b (diff) | |
download | coredns-b8e2c476a5535a35daa54ef4e13e627ffa5cb912.tar.gz coredns-b8e2c476a5535a35daa54ef4e13e627ffa5cb912.tar.zst coredns-b8e2c476a5535a35daa54ef4e13e627ffa5cb912.zip |
mw/authpath: hook in kubernetees (#860)
Call out to kubernetes to get the search path - this still needs
to return something sensible, but all infrastructure has landed
to make it work.
Diffstat (limited to 'middleware/kubernetes/autopath.go')
-rw-r--r-- | middleware/kubernetes/autopath.go | 31 |
1 files changed, 26 insertions, 5 deletions
diff --git a/middleware/kubernetes/autopath.go b/middleware/kubernetes/autopath.go index 3d677e4df..4c5870c6b 100644 --- a/middleware/kubernetes/autopath.go +++ b/middleware/kubernetes/autopath.go @@ -1,11 +1,32 @@ package kubernetes -import "k8s.io/client-go/1.5/pkg/api" +import ( + "fmt" -// TODO(miek): rename and put in autopath.go file. This will be for the -// external middleware autopath to use. Mostly to get the namespace: -//name, path, ok := autopath.SplitSearch(zone, state.QName(), p.Namespace) -func (k *Kubernetes) findPodWithIP(ip string) (p *api.Pod) { + "github.com/coredns/coredns/request" + + "k8s.io/client-go/1.5/pkg/api" +) + +func (k *Kubernetes) AutoPath(state request.Request) ([]string, error) { + ip := state.IP() + + pod := k.PodWithIP(ip) + if pod == nil { + return nil, fmt.Errorf("kubernets: no pod found for %s", ip) + } + + // something something namespace + namespace := pod.Namespace + + search := []string{namespace} // TODO: way more + + search = append(search, "") // sentinal + return search, nil +} + +// PodWithIP return the api.Pod for source IP ip. It return nil if nothing can be found. +func (k *Kubernetes) PodWithIP(ip string) (p *api.Pod) { objList := k.APIConn.PodIndex(ip) for _, o := range objList { p, ok := o.(*api.Pod) |