35 lines
1.2 KiB
Go
35 lines
1.2 KiB
Go
// Package upstream abstracts a upstream lookups so that plugins can handle them in an unified way.
|
|
package upstream
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/coredns/coredns/core/dnsserver"
|
|
"github.com/coredns/coredns/plugin/pkg/nonwriter"
|
|
"github.com/coredns/coredns/request"
|
|
|
|
"github.com/miekg/dns"
|
|
)
|
|
|
|
// Upstream is used to resolve CNAME or other external targets via CoreDNS itself.
|
|
type Upstream struct{}
|
|
|
|
// New creates a new Upstream to resolve names using the coredns process.
|
|
func New() *Upstream { return &Upstream{} }
|
|
|
|
// Lookup routes lookups to our selves to make it follow the plugin chain *again*, but with a (possibly) new query. As
|
|
// we are doing the query against ourselves again, there is no actual new hop, as such RFC 6891 does not apply and we
|
|
// need the EDNS0 option present in the *original* query to be present here too.
|
|
func (u *Upstream) Lookup(ctx context.Context, state request.Request, name string, typ uint16) (*dns.Msg, error) {
|
|
server, ok := ctx.Value(dnsserver.Key{}).(*dnsserver.Server)
|
|
if !ok {
|
|
return nil, fmt.Errorf("no full server is running")
|
|
}
|
|
req := state.NewWithQuestion(name, typ)
|
|
|
|
nw := nonwriter.New(state.W)
|
|
server.ServeDNS(ctx, nw, req.Req)
|
|
|
|
return nw.Msg, nil
|
|
}
|