mirror of
				https://github.com/coredns/coredns.git
				synced 2025-11-04 02:01:07 +01:00 
			
		
		
		
	* Fix EDNS0 compliance Do SizeAndDo in the server (ScrubWriter) and remove all uses of this from the plugins. Also *always* do it. This is to get into compliance for https://dnsflagday.net/. The pkg/edns0 now exports the EDNS0 options we understand; this is exported to allow plugins add things there. The *rewrite* plugin used this to add custom EDNS0 option codes that the server needs to understand. This also needs a new release of miekg/dns because it triggered a race-condition that was basicly there forever. See: * https://github.com/miekg/dns/issues/857 * https://github.com/miekg/dns/pull/859 Running a test instance and pointing the https://ednscomp.isc.org/ednscomp to it shows the tests are now fixed: ~~~ EDNS Compliance Tester Checking: 'miek.nl' as at 2018-12-01T17:53:15Z miek.nl. @147.75.204.203 (drone.coredns.io.): dns=ok edns=ok edns1=ok edns@512=ok ednsopt=ok edns1opt=ok do=ok ednsflags=ok docookie=ok edns512tcp=ok optlist=ok miek.nl. @2604:1380:2002:a000::1 (drone.coredns.io.): dns=ok edns=ok edns1=ok edns@512=ok ednsopt=ok edns1opt=ok do=ok ednsflags=ok docookie=ok edns512tcp=ok optlist=ok All Ok Codes ok - test passed. ~~~ Signed-off-by: Miek Gieben <miek@miek.nl> Signed-off-by: Miek Gieben <miek@miek.nl> * typos in comments Signed-off-by: Miek Gieben <miek@miek.nl>
		
			
				
	
	
		
			112 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Package erratic implements a plugin that returns erratic answers (delayed, dropped).
 | 
						|
package erratic
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"sync/atomic"
 | 
						|
	"time"
 | 
						|
 | 
						|
	"github.com/coredns/coredns/request"
 | 
						|
 | 
						|
	"github.com/miekg/dns"
 | 
						|
)
 | 
						|
 | 
						|
// Erratic is a plugin that returns erratic responses to each client.
 | 
						|
type Erratic struct {
 | 
						|
	drop uint64
 | 
						|
 | 
						|
	delay    uint64
 | 
						|
	duration time.Duration
 | 
						|
 | 
						|
	truncate uint64
 | 
						|
	large    bool // undocumented feature; return large responses for A request (>512B, to test compression).
 | 
						|
 | 
						|
	q uint64 // counter of queries
 | 
						|
}
 | 
						|
 | 
						|
// ServeDNS implements the plugin.Handler interface.
 | 
						|
func (e *Erratic) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (int, error) {
 | 
						|
	state := request.Request{W: w, Req: r}
 | 
						|
	drop := false
 | 
						|
	delay := false
 | 
						|
	trunc := false
 | 
						|
 | 
						|
	queryNr := atomic.LoadUint64(&e.q)
 | 
						|
	atomic.AddUint64(&e.q, 1)
 | 
						|
 | 
						|
	if e.drop > 0 && queryNr%e.drop == 0 {
 | 
						|
		drop = true
 | 
						|
	}
 | 
						|
	if e.delay > 0 && queryNr%e.delay == 0 {
 | 
						|
		delay = true
 | 
						|
	}
 | 
						|
	if e.truncate > 0 && queryNr&e.truncate == 0 {
 | 
						|
		trunc = true
 | 
						|
	}
 | 
						|
 | 
						|
	m := new(dns.Msg)
 | 
						|
	m.SetReply(r)
 | 
						|
	m.Authoritative = true
 | 
						|
	if trunc {
 | 
						|
		m.Truncated = true
 | 
						|
	}
 | 
						|
 | 
						|
	// small dance to copy rrA or rrAAAA into a non-pointer var that allows us to overwrite the ownername
 | 
						|
	// in a non-racy way.
 | 
						|
	switch state.QType() {
 | 
						|
	case dns.TypeA:
 | 
						|
		rr := *(rrA.(*dns.A))
 | 
						|
		rr.Header().Name = state.QName()
 | 
						|
		m.Answer = append(m.Answer, &rr)
 | 
						|
		if e.large {
 | 
						|
			for i := 0; i < 29; i++ {
 | 
						|
				m.Answer = append(m.Answer, &rr)
 | 
						|
			}
 | 
						|
		}
 | 
						|
	case dns.TypeAAAA:
 | 
						|
		rr := *(rrAAAA.(*dns.AAAA))
 | 
						|
		rr.Header().Name = state.QName()
 | 
						|
		m.Answer = append(m.Answer, &rr)
 | 
						|
	case dns.TypeAXFR:
 | 
						|
		if drop {
 | 
						|
			return 0, nil
 | 
						|
		}
 | 
						|
		if delay {
 | 
						|
			time.Sleep(e.duration)
 | 
						|
		}
 | 
						|
 | 
						|
		xfr(state, trunc)
 | 
						|
		return 0, nil
 | 
						|
 | 
						|
	default:
 | 
						|
		if drop {
 | 
						|
			return 0, nil
 | 
						|
		}
 | 
						|
		if delay {
 | 
						|
			time.Sleep(e.duration)
 | 
						|
		}
 | 
						|
		// coredns will return error.
 | 
						|
		return dns.RcodeServerFailure, nil
 | 
						|
	}
 | 
						|
 | 
						|
	if drop {
 | 
						|
		return 0, nil
 | 
						|
	}
 | 
						|
 | 
						|
	if delay {
 | 
						|
		time.Sleep(e.duration)
 | 
						|
	}
 | 
						|
 | 
						|
	w.WriteMsg(m)
 | 
						|
 | 
						|
	return 0, nil
 | 
						|
}
 | 
						|
 | 
						|
// Name implements the Handler interface.
 | 
						|
func (e *Erratic) Name() string { return "erratic" }
 | 
						|
 | 
						|
var (
 | 
						|
	rrA, _    = dns.NewRR(". IN 0 A 192.0.2.53")
 | 
						|
	rrAAAA, _ = dns.NewRR(". IN 0 AAAA 2001:DB8::53")
 | 
						|
)
 |