mirror of
				https://github.com/coredns/coredns.git
				synced 2025-10-31 18:23:13 -04:00 
			
		
		
		
	This PR adds a middleware that talks to dns.google.com over HTTPS, meaning all your DNS traffic is encrypted when traversing your ISP and the internet. The `dns.google.com` address is re-resolved every 30 seconds.
		
			
				
	
	
		
			33 lines
		
	
	
		
			565 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			565 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| package httpproxy
 | |
| 
 | |
| import (
 | |
| 	"crypto/tls"
 | |
| 	"net/http"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/miekg/dns"
 | |
| )
 | |
| 
 | |
| // Exchanger is an interface that specifies a type implementing a DNS resolver that
 | |
| // uses a HTTPS server.
 | |
| type Exchanger interface {
 | |
| 	Exchange(*dns.Msg) (*dns.Msg, error)
 | |
| 
 | |
| 	SetUpstream(*simpleUpstream) error
 | |
| 	OnStartup() error
 | |
| 	OnShutdown() error
 | |
| }
 | |
| 
 | |
| func newClient(sni string) *http.Client {
 | |
| 	tls := &tls.Config{ServerName: sni}
 | |
| 
 | |
| 	c := &http.Client{
 | |
| 		Timeout:   time.Second * timeOut,
 | |
| 		Transport: &http.Transport{TLSClientConfig: tls},
 | |
| 	}
 | |
| 
 | |
| 	return c
 | |
| }
 | |
| 
 | |
| const timeOut = 5
 |