| 
									
										
										
										
											2017-05-22 16:05:48 -04:00
										 |  |  | package kubernetes | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"net" | 
					
						
							|  |  |  | 	"strings" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/miekg/dns" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-18 14:45:20 +01:00
										 |  |  | func isDefaultNS(name, zone string) bool { | 
					
						
							|  |  |  | 	return strings.Index(name, defaultNSName) == 0 && strings.Index(name, zone) == len(defaultNSName) | 
					
						
							| 
									
										
										
										
											2017-05-22 16:05:48 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-23 12:54:06 -04:00
										 |  |  | // nsAddrs returns the A or AAAA records for the CoreDNS service in the cluster. If the service cannot be found, | 
					
						
							| 
									
										
										
										
											2019-08-28 14:18:33 +08:00
										 |  |  | // it returns a record for the local address of the machine we're running on. | 
					
						
							| 
									
										
										
										
											2022-08-30 20:59:27 +02:00
										 |  |  | func (k *Kubernetes) nsAddrs(external, headless bool, zone string) []dns.RR { | 
					
						
							| 
									
										
										
										
											2017-08-03 23:14:11 -07:00
										 |  |  | 	var ( | 
					
						
							| 
									
										
										
										
											2022-03-07 12:18:23 -05:00
										 |  |  | 		svcNames      []string | 
					
						
							|  |  |  | 		svcIPs        []net.IP | 
					
						
							|  |  |  | 		foundEndpoint bool | 
					
						
							| 
									
										
										
										
											2017-08-03 23:14:11 -07:00
										 |  |  | 	) | 
					
						
							| 
									
										
										
										
											2017-05-22 16:05:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-05 09:07:55 -04:00
										 |  |  | 	// Find the CoreDNS Endpoints | 
					
						
							|  |  |  | 	for _, localIP := range k.localIPs { | 
					
						
							|  |  |  | 		endpoints := k.APIConn.EpIndexReverse(localIP.String()) | 
					
						
							| 
									
										
										
										
											2017-05-22 16:05:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-23 12:54:06 -04:00
										 |  |  | 		// Collect IPs for all Services of the Endpoints | 
					
						
							|  |  |  | 		for _, endpoint := range endpoints { | 
					
						
							| 
									
										
										
										
											2022-03-07 12:18:23 -05:00
										 |  |  | 			foundEndpoint = true | 
					
						
							| 
									
										
										
										
											2020-10-30 08:14:30 -04:00
										 |  |  | 			svcs := k.APIConn.SvcIndex(endpoint.Index) | 
					
						
							| 
									
										
										
										
											2019-08-23 12:54:06 -04:00
										 |  |  | 			for _, svc := range svcs { | 
					
						
							|  |  |  | 				if external { | 
					
						
							|  |  |  | 					svcName := strings.Join([]string{svc.Name, svc.Namespace, zone}, ".") | 
					
						
							| 
									
										
										
										
											2022-08-30 20:59:27 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 					if headless && svc.Headless() { | 
					
						
							|  |  |  | 						for _, s := range endpoint.Subsets { | 
					
						
							|  |  |  | 							for _, a := range s.Addresses { | 
					
						
							|  |  |  | 								svcNames = append(svcNames, endpointHostname(a, k.endpointNameMode)+"."+svcName) | 
					
						
							|  |  |  | 								svcIPs = append(svcIPs, net.ParseIP(a.IP)) | 
					
						
							|  |  |  | 							} | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} else { | 
					
						
							|  |  |  | 						for _, exIP := range svc.ExternalIPs { | 
					
						
							|  |  |  | 							svcNames = append(svcNames, svcName) | 
					
						
							|  |  |  | 							svcIPs = append(svcIPs, net.ParseIP(exIP)) | 
					
						
							|  |  |  | 						} | 
					
						
							| 
									
										
										
										
											2019-08-23 12:54:06 -04:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2022-08-30 20:59:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-23 12:54:06 -04:00
										 |  |  | 					continue | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				svcName := strings.Join([]string{svc.Name, svc.Namespace, Svc, zone}, ".") | 
					
						
							| 
									
										
										
										
											2020-12-21 05:30:24 -05:00
										 |  |  | 				if svc.Headless() { | 
					
						
							| 
									
										
										
										
											2019-08-23 12:54:06 -04:00
										 |  |  | 					// For a headless service, use the endpoints IPs | 
					
						
							|  |  |  | 					for _, s := range endpoint.Subsets { | 
					
						
							|  |  |  | 						for _, a := range s.Addresses { | 
					
						
							|  |  |  | 							svcNames = append(svcNames, endpointHostname(a, k.endpointNameMode)+"."+svcName) | 
					
						
							|  |  |  | 							svcIPs = append(svcIPs, net.ParseIP(a.IP)) | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} else { | 
					
						
							| 
									
										
										
										
											2020-12-21 05:30:24 -05:00
										 |  |  | 					for _, clusterIP := range svc.ClusterIPs { | 
					
						
							|  |  |  | 						svcNames = append(svcNames, svcName) | 
					
						
							|  |  |  | 						svcIPs = append(svcIPs, net.ParseIP(clusterIP)) | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2017-05-22 16:05:48 -04:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-08-10 23:13:08 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-05-22 16:05:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-07 12:18:23 -05:00
										 |  |  | 	// If no CoreDNS endpoints were found, use the localIPs directly | 
					
						
							|  |  |  | 	if !foundEndpoint { | 
					
						
							| 
									
										
										
										
											2019-09-05 09:07:55 -04:00
										 |  |  | 		svcIPs = make([]net.IP, len(k.localIPs)) | 
					
						
							|  |  |  | 		svcNames = make([]string, len(k.localIPs)) | 
					
						
							|  |  |  | 		for i, localIP := range k.localIPs { | 
					
						
							|  |  |  | 			svcNames[i] = defaultNSName + zone | 
					
						
							|  |  |  | 			svcIPs[i] = localIP | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-23 12:54:06 -04:00
										 |  |  | 	// Create an RR slice of collected IPs | 
					
						
							| 
									
										
										
										
											2019-09-27 18:10:34 +08:00
										 |  |  | 	rrs := make([]dns.RR, len(svcIPs)) | 
					
						
							| 
									
										
										
										
											2019-08-23 12:54:06 -04:00
										 |  |  | 	for i, ip := range svcIPs { | 
					
						
							|  |  |  | 		if ip.To4() == nil { | 
					
						
							|  |  |  | 			rr := new(dns.AAAA) | 
					
						
							|  |  |  | 			rr.Hdr.Class = dns.ClassINET | 
					
						
							|  |  |  | 			rr.Hdr.Rrtype = dns.TypeAAAA | 
					
						
							|  |  |  | 			rr.Hdr.Name = svcNames[i] | 
					
						
							|  |  |  | 			rr.AAAA = ip | 
					
						
							|  |  |  | 			rrs[i] = rr | 
					
						
							|  |  |  | 			continue | 
					
						
							| 
									
										
										
										
											2017-05-22 16:05:48 -04:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2019-08-23 12:54:06 -04:00
										 |  |  | 		rr := new(dns.A) | 
					
						
							|  |  |  | 		rr.Hdr.Class = dns.ClassINET | 
					
						
							|  |  |  | 		rr.Hdr.Rrtype = dns.TypeA | 
					
						
							|  |  |  | 		rr.Hdr.Name = svcNames[i] | 
					
						
							|  |  |  | 		rr.A = ip | 
					
						
							|  |  |  | 		rrs[i] = rr | 
					
						
							| 
									
										
										
										
											2017-05-22 16:05:48 -04:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-08-10 23:13:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-23 12:54:06 -04:00
										 |  |  | 	return rrs | 
					
						
							| 
									
										
										
										
											2017-05-22 16:05:48 -04:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2017-08-10 23:13:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | const defaultNSName = "ns.dns." |