DEVELOPMENT ENVIRONMENT

~liljamo/felu

08a7a55902c758aaf1432ce557f0143715c363ee — Jonni Liljamo 2 months ago ce7ae43
feat: tsig
1 files changed, 14 insertions(+), 0 deletions(-)

M internal/dns/handle.go
M internal/dns/handle.go => internal/dns/handle.go +14 -0
@@ 9,6 9,7 @@ package dns

import (
	"log/slog"
	"time"

	"github.com/miekg/dns"
)


@@ 19,6 20,19 @@ func handleDNSRequest(w dns.ResponseWriter, r *dns.Msg) {
	m.Compress = false
	m.SetEdns0(4096, true)

	if r.IsTsig() != nil {
		slog.Debug("Request is TSIG")
		if w.TsigStatus() == nil {
			slog.Debug("TSIG is valid")
			// NOTE: The first argument here is the keyname.
			m.SetTsig(r.Extra[len(r.Extra)-1].(*dns.TSIG).Hdr.Name, dns.HmacSHA256, 300, time.Now().Unix())
		} else {
			slog.Error("TSIG error", slog.String("status", w.TsigStatus().Error()))
			// Stop processing the request if there was something wrong with TSIG.
			return
		}
	}

	switch r.Opcode {
	case dns.OpcodeQuery:
		parseQuery(m, r)