2023-01-27 13:37:20 -08:00
|
|
|
// Copyright (c) Tailscale Inc & AUTHORS
|
|
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
2021-08-05 14:05:24 -07:00
|
|
|
|
|
|
|
// Package dnstype defines types for working with DNS.
|
|
|
|
package dnstype
|
|
|
|
|
2022-08-02 09:57:10 -07:00
|
|
|
//go:generate go run tailscale.com/cmd/viewer --type=Resolver --clonefunc=true
|
2021-08-05 14:05:24 -07:00
|
|
|
|
2022-07-25 20:55:44 -07:00
|
|
|
import (
|
|
|
|
"net/netip"
|
2023-09-14 10:04:31 -07:00
|
|
|
"slices"
|
2022-07-25 20:55:44 -07:00
|
|
|
)
|
2021-08-05 14:05:24 -07:00
|
|
|
|
|
|
|
// Resolver is the configuration for one DNS resolver.
|
|
|
|
type Resolver struct {
|
|
|
|
// Addr is the address of the DNS resolver, one of:
|
2022-04-18 21:58:00 -07:00
|
|
|
// - A plain IP address for a "classic" UDP+TCP DNS resolver.
|
|
|
|
// This is the common format as sent by the control plane.
|
|
|
|
// - An IP:port, for tests.
|
2022-09-08 15:54:29 -07:00
|
|
|
// - "https://resolver.com/path" for DNS over HTTPS; currently
|
|
|
|
// as of 2022-09-08 only used for certain well-known resolvers
|
|
|
|
// (see the publicdns package) for which the IP addresses to dial DoH are
|
|
|
|
// known ahead of time, so bootstrap DNS resolution is not required.
|
2021-08-05 14:05:24 -07:00
|
|
|
// - [TODO] "tls://resolver.com" for DNS over TCP+TLS
|
|
|
|
Addr string `json:",omitempty"`
|
|
|
|
|
|
|
|
// BootstrapResolution is an optional suggested resolution for the
|
|
|
|
// DoT/DoH resolver, if the resolver URL does not reference an IP
|
|
|
|
// address directly.
|
|
|
|
// BootstrapResolution may be empty, in which case clients should
|
|
|
|
// look up the DoT/DoH server using their local "classic" DNS
|
|
|
|
// resolver.
|
2022-09-08 15:54:29 -07:00
|
|
|
//
|
|
|
|
// As of 2022-09-08, BootstrapResolution is not yet used.
|
all: convert more code to use net/netip directly
perl -i -npe 's,netaddr.IPPrefixFrom,netip.PrefixFrom,' $(git grep -l -F netaddr.)
perl -i -npe 's,netaddr.IPPortFrom,netip.AddrPortFrom,' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPPrefix,netip.Prefix,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPPort,netip.AddrPort,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IP\b,netip.Addr,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPv6Raw\b,netip.AddrFrom16,g' $(git grep -l -F netaddr. )
goimports -w .
Then delete some stuff from the net/netaddr shim package which is no
longer neeed.
Updates #5162
Change-Id: Ia7a86893fe21c7e3ee1ec823e8aba288d4566cd8
Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
2022-07-25 21:14:09 -07:00
|
|
|
BootstrapResolution []netip.Addr `json:",omitempty"`
|
2021-08-05 14:05:24 -07:00
|
|
|
}
|
2021-08-03 06:56:31 -07:00
|
|
|
|
2022-04-18 21:58:00 -07:00
|
|
|
// IPPort returns r.Addr as an IP address and port if either
|
|
|
|
// r.Addr is an IP address (the common case) or if r.Addr
|
|
|
|
// is an IP:port (as done in tests).
|
all: convert more code to use net/netip directly
perl -i -npe 's,netaddr.IPPrefixFrom,netip.PrefixFrom,' $(git grep -l -F netaddr.)
perl -i -npe 's,netaddr.IPPortFrom,netip.AddrPortFrom,' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPPrefix,netip.Prefix,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPPort,netip.AddrPort,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IP\b,netip.Addr,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPv6Raw\b,netip.AddrFrom16,g' $(git grep -l -F netaddr. )
goimports -w .
Then delete some stuff from the net/netaddr shim package which is no
longer neeed.
Updates #5162
Change-Id: Ia7a86893fe21c7e3ee1ec823e8aba288d4566cd8
Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
2022-07-25 21:14:09 -07:00
|
|
|
func (r *Resolver) IPPort() (ipp netip.AddrPort, ok bool) {
|
2022-04-18 21:58:00 -07:00
|
|
|
if r.Addr == "" || r.Addr[0] == 'h' || r.Addr[0] == 't' {
|
|
|
|
// Fast path to avoid ParseIP error allocation for obviously not IP
|
|
|
|
// cases.
|
|
|
|
return
|
|
|
|
}
|
2022-07-25 20:55:44 -07:00
|
|
|
if ip, err := netip.ParseAddr(r.Addr); err == nil {
|
all: convert more code to use net/netip directly
perl -i -npe 's,netaddr.IPPrefixFrom,netip.PrefixFrom,' $(git grep -l -F netaddr.)
perl -i -npe 's,netaddr.IPPortFrom,netip.AddrPortFrom,' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPPrefix,netip.Prefix,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPPort,netip.AddrPort,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IP\b,netip.Addr,g' $(git grep -l -F netaddr. )
perl -i -npe 's,netaddr.IPv6Raw\b,netip.AddrFrom16,g' $(git grep -l -F netaddr. )
goimports -w .
Then delete some stuff from the net/netaddr shim package which is no
longer neeed.
Updates #5162
Change-Id: Ia7a86893fe21c7e3ee1ec823e8aba288d4566cd8
Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
2022-07-25 21:14:09 -07:00
|
|
|
return netip.AddrPortFrom(ip, 53), true
|
2022-04-18 21:58:00 -07:00
|
|
|
}
|
2022-07-25 20:55:44 -07:00
|
|
|
if ipp, err := netip.ParseAddrPort(r.Addr); err == nil {
|
2022-04-18 21:58:00 -07:00
|
|
|
return ipp, true
|
|
|
|
}
|
|
|
|
return
|
2021-08-03 06:56:31 -07:00
|
|
|
}
|
2023-09-14 10:04:31 -07:00
|
|
|
|
|
|
|
// Equal reports whether r and other are equal.
|
|
|
|
func (r *Resolver) Equal(other *Resolver) bool {
|
|
|
|
if r == nil || other == nil {
|
|
|
|
return r == other
|
|
|
|
}
|
|
|
|
if r == other {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
return r.Addr == other.Addr && slices.Equal(r.BootstrapResolution, other.BootstrapResolution)
|
|
|
|
}
|