| 
									
										
										
										
											2017-08-18 14:45:20 +01:00
										 |  |  | package kubernetes
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import (
 | 
					
						
							| 
									
										
										
										
											2017-09-14 09:36:06 +01:00
										 |  |  | 	"github.com/coredns/coredns/plugin/etcd/msg"
 | 
					
						
							|  |  |  | 	"github.com/coredns/coredns/plugin/pkg/dnsutil"
 | 
					
						
							| 
									
										
										
										
											2017-08-18 14:45:20 +01:00
										 |  |  | 	"github.com/coredns/coredns/request"
 | 
					
						
							|  |  |  | )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // The federation node.Labels keys used.
 | 
					
						
							|  |  |  | const (
 | 
					
						
							|  |  |  | 	// TODO: Do not hardcode these labels. Pull them out of the API instead.
 | 
					
						
							|  |  |  | 	//
 | 
					
						
							|  |  |  | 	// We can get them via ....
 | 
					
						
							|  |  |  | 	//   import metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
 | 
					
						
							|  |  |  | 	//     metav1.LabelZoneFailureDomain
 | 
					
						
							|  |  |  | 	//     metav1.LabelZoneRegion
 | 
					
						
							|  |  |  | 	//
 | 
					
						
							|  |  |  | 	// But importing above breaks coredns with flag collision of 'log_dir'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	LabelZone   = "failure-domain.beta.kubernetes.io/zone"
 | 
					
						
							|  |  |  | 	LabelRegion = "failure-domain.beta.kubernetes.io/region"
 | 
					
						
							|  |  |  | )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-14 09:36:06 +01:00
										 |  |  | // Federations is used from the federations plugin to return the service that should be
 | 
					
						
							| 
									
										
										
										
											2017-08-18 14:45:20 +01:00
										 |  |  | // returned as a CNAME for federation(s) to work.
 | 
					
						
							|  |  |  | func (k *Kubernetes) Federations(state request.Request, fname, fzone string) (msg.Service, error) {
 | 
					
						
							|  |  |  | 	nodeName := k.localNodeName()
 | 
					
						
							|  |  |  | 	node, err := k.APIConn.GetNodeByName(nodeName)
 | 
					
						
							|  |  |  | 	if err != nil {
 | 
					
						
							|  |  |  | 		return msg.Service{}, err
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							| 
									
										
										
										
											2017-08-23 07:19:41 +01:00
										 |  |  | 	r, err := parseRequest(state)
 | 
					
						
							| 
									
										
										
										
											2017-09-01 10:21:05 -07:00
										 |  |  | 	if err != nil {
 | 
					
						
							|  |  |  | 		return msg.Service{}, err
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							| 
									
										
										
										
											2017-08-18 14:45:20 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	lz := node.Labels[LabelZone]
 | 
					
						
							|  |  |  | 	lr := node.Labels[LabelRegion]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if r.endpoint == "" {
 | 
					
						
							| 
									
										
										
										
											2017-08-19 15:22:09 +01:00
										 |  |  | 		return msg.Service{Host: dnsutil.Join([]string{r.service, r.namespace, fname, r.podOrSvc, lz, lr, fzone})}, nil
 | 
					
						
							| 
									
										
										
										
											2017-08-18 14:45:20 +01:00
										 |  |  | 	}
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-19 15:22:09 +01:00
										 |  |  | 	return msg.Service{Host: dnsutil.Join([]string{r.endpoint, r.service, r.namespace, fname, r.podOrSvc, lz, lr, fzone})}, nil
 | 
					
						
							| 
									
										
										
										
											2017-08-18 14:45:20 +01:00
										 |  |  | }
 |