* add bufsize plugin Signed-off-by: ykhr53 <yukihira.lab@gmail.com> * add docstring and comment Signed-off-by: ykhr53 <yukihira.lab@gmail.com> * delete stdout messages when get an error Signed-off-by: ykhr53 <yukihira.lab@gmail.com> * change to context.Background from TODO Signed-off-by: ykhr53 <yukihira.lab@gmail.com> * define default bufsize as defaultBufSize constant Signed-off-by: ykhr53 <yukihira.lab@gmail.com> * fix some comments Signed-off-by: ykhr53 <yukihira.lab@gmail.com> * function name change: parse Signed-off-by: ykhr53 <yukihira.lab@gmail.com> * function name change: parse Signed-off-by: ykhr53 <yukihira.lab@gmail.com>
31 lines
757 B
Go
31 lines
757 B
Go
// Package bufsize implements a plugin that modifies EDNS0 buffer size.
|
|
package bufsize
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/coredns/coredns/plugin"
|
|
|
|
"github.com/miekg/dns"
|
|
)
|
|
|
|
// Bufsize implements bufsize plugin.
|
|
type Bufsize struct {
|
|
Next plugin.Handler
|
|
Size int
|
|
}
|
|
|
|
// ServeDNS implements the plugin.Handler interface.
|
|
func (buf Bufsize) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (int, error) {
|
|
if option := r.IsEdns0(); option != nil {
|
|
option.SetUDPSize(uint16(buf.Size))
|
|
} else {
|
|
// If a client does not use EDNS, add it
|
|
r.SetEdns0(uint16(buf.Size), false)
|
|
}
|
|
|
|
return plugin.NextOrFailure(buf.Name(), buf.Next, ctx, w, r)
|
|
}
|
|
|
|
// Name implements the Handler interface.
|
|
func (buf Bufsize) Name() string { return "bufsize" }
|