| 
									
										
										
										
											2017-08-18 14:45:20 +01:00
										 |  |  | package kubernetes | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2018-09-12 02:07:24 -04:00
										 |  |  | 	"errors" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-12 02:07:24 -04:00
										 |  |  | 	if lz == "" || lr == "" { | 
					
						
							|  |  |  | 		return msg.Service{}, errors.New("local node missing zone/region labels") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-18 14:45:20 +01:00
										 |  |  | 	if r.endpoint == "" { | 
					
						
							| 
									
										
										
										
											2018-09-22 15:12:02 +01:00
										 |  |  | 		return msg.Service{Host: dnsutil.Join(r.service, r.namespace, fname, r.podOrSvc, lz, lr, fzone)}, nil | 
					
						
							| 
									
										
										
										
											2017-08-18 14:45:20 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-22 15:12:02 +01:00
										 |  |  | 	return msg.Service{Host: dnsutil.Join(r.endpoint, r.service, r.namespace, fname, r.podOrSvc, lz, lr, fzone)}, nil | 
					
						
							| 
									
										
										
										
											2017-08-18 14:45:20 +01:00
										 |  |  | } |