mirror of
				https://github.com/coredns/coredns.git
				synced 2025-10-31 10:13:14 -04:00 
			
		
		
		
	* Extend bind to allow multiple addresses. UTs added. Changes the log for server starting, adding address when available * update readme for bind * fixes after review * minor fix on readme * accept multiple BIND directives in blocserver, consolidate the addresses * fixes after review - format logging server address, variable names
		
			
				
	
	
		
			84 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package dnsserver
 | |
| 
 | |
| import (
 | |
| 	"crypto/tls"
 | |
| 	"net"
 | |
| 
 | |
| 	"github.com/coredns/coredns/plugin"
 | |
| 
 | |
| 	"github.com/mholt/caddy"
 | |
| )
 | |
| 
 | |
| // Config configuration for a single server.
 | |
| type Config struct {
 | |
| 	// The zone of the site.
 | |
| 	Zone string
 | |
| 
 | |
| 	// one or several hostnames to bind the server to.
 | |
| 	// defaults to a single empty string that denote the wildcard address
 | |
| 	ListenHosts []string
 | |
| 
 | |
| 	// The port to listen on.
 | |
| 	Port string
 | |
| 
 | |
| 	// Root points to a base directory we we find user defined "things".
 | |
| 	// First consumer is the file plugin to looks for zone files in this place.
 | |
| 	Root string
 | |
| 
 | |
| 	// Debug controls the panic/recover mechanism that is enabled by default.
 | |
| 	Debug bool
 | |
| 
 | |
| 	// The transport we implement, normally just "dns" over TCP/UDP, but could be
 | |
| 	// DNS-over-TLS or DNS-over-gRPC.
 | |
| 	Transport string
 | |
| 
 | |
| 	// If this function is not nil it will be used to further filter access
 | |
| 	// to this handler. The primary use is to limit access to a reverse zone
 | |
| 	// on a non-octet boundary, i.e. /17
 | |
| 	FilterFunc func(string) bool
 | |
| 
 | |
| 	// TLSConfig when listening for encrypted connections (gRPC, DNS-over-TLS).
 | |
| 	TLSConfig *tls.Config
 | |
| 
 | |
| 	// Plugin stack.
 | |
| 	Plugin []plugin.Plugin
 | |
| 
 | |
| 	// Compiled plugin stack.
 | |
| 	pluginChain plugin.Handler
 | |
| 
 | |
| 	// Plugin interested in announcing that they exist, so other plugin can call methods
 | |
| 	// on them should register themselves here. The name should be the name as return by the
 | |
| 	// Handler's Name method.
 | |
| 	registry map[string]plugin.Handler
 | |
| }
 | |
| 
 | |
| //HostAddresses builds a representation of the addresses of this Config
 | |
| //after server is started ONLY, can be used as a Key for identifing that config
 | |
| // :53 or 127.0.0.1:53 or 127.0.0.1:53/::1:53
 | |
| func (c *Config) HostAddresses() string {
 | |
| 	all := ""
 | |
| 	for _, h := range c.ListenHosts {
 | |
| 		addr := net.JoinHostPort(h, c.Port)
 | |
| 		if all == "" {
 | |
| 			all = addr
 | |
| 			continue
 | |
| 		}
 | |
| 		all = all + "/" + addr
 | |
| 	}
 | |
| 	return all
 | |
| }
 | |
| 
 | |
| // GetConfig gets the Config that corresponds to c.
 | |
| // If none exist nil is returned.
 | |
| func GetConfig(c *caddy.Controller) *Config {
 | |
| 	ctx := c.Context().(*dnsContext)
 | |
| 	if cfg, ok := ctx.keysToConfigs[c.Key]; ok {
 | |
| 		return cfg
 | |
| 	}
 | |
| 	// we should only get here during tests because directive
 | |
| 	// actions typically skip the server blocks where we make
 | |
| 	// the configs.
 | |
| 	ctx.saveConfig(c.Key, &Config{ListenHosts: []string{""}})
 | |
| 	return GetConfig(c)
 | |
| }
 |