mirror of
				https://github.com/coredns/coredns.git
				synced 2025-10-29 01:04:15 -04: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")
 | |
| )
 |