mirror of
				https://github.com/coredns/coredns.git
				synced 2025-10-31 18:23:13 -04:00 
			
		
		
		
	* Add ServiceBackend interface This adds a ServiceBackend interface that is shared between etcd/etcd3 (later) and kubernetes, leading to a massive reduction in code. When returning the specific records from their backend. Fixes #273
		
			
				
	
	
		
			51 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package kubernetes
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"net"
 | |
| 
 | |
| 	"github.com/miekg/coredns/middleware/etcd/msg"
 | |
| 	"github.com/miekg/coredns/middleware/pkg/dnsutil"
 | |
| 	"github.com/miekg/coredns/request"
 | |
| 
 | |
| 	"github.com/miekg/dns"
 | |
| )
 | |
| 
 | |
| func (k Kubernetes) records(state request.Request, exact bool) ([]msg.Service, error) {
 | |
| 	services, err := k.Records(state.Name(), exact)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	services = msg.Group(services)
 | |
| 	return services, nil
 | |
| }
 | |
| 
 | |
| // PTR Record returns PTR records from kubernetes.
 | |
| func (k Kubernetes) PTR(zone string, state request.Request) ([]dns.RR, error) {
 | |
| 	reverseIP := dnsutil.ExtractAddressFromReverse(state.Name())
 | |
| 	if reverseIP == "" {
 | |
| 		return nil, fmt.Errorf("does not support reverse lookup for %s", state.QName())
 | |
| 	}
 | |
| 
 | |
| 	records := make([]dns.RR, 1)
 | |
| 	services, err := k.records(state, false)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	for _, serv := range services {
 | |
| 		ip := net.ParseIP(serv.Host)
 | |
| 		if reverseIP != serv.Host {
 | |
| 			continue
 | |
| 		}
 | |
| 		switch {
 | |
| 		case ip.To4() != nil:
 | |
| 			records = append(records, serv.NewPTR(state.QName(), ip.To4().String()))
 | |
| 			break
 | |
| 		case ip.To4() == nil:
 | |
| 			// nodata?
 | |
| 		}
 | |
| 	}
 | |
| 	return records, nil
 | |
| }
 |