Documentation ¶
Overview ¶
Package resolver provides the implementation of Penne resolvers
Index ¶
Constants ¶
View Source
const ( // DefaultIteratorMaxRR indicates the number of records // the Iterator lookuper will cache. DefaultIteratorMaxRR = 1024 )
Variables ¶
This section is empty.
Functions ¶
Types ¶
type Config ¶
type Config struct { // Name is the unique name of this [Resolver] Name string `yaml:""` // Next is the name of the resolver to use if the Suffixes restriction // isn't satisfied. Next string `yaml:",omitempty" toml:",omitempty" json:",omitempty"` // Debug indicates the requests passing through this [Resolver] should be logged or not. Debug bool `yaml:",omitempty" toml:",omitempty" json:",omitempty"` // OmitSubNet indicates requests reaching out to remote servers should omit // EDNS0 SUBNET information. OmitSubNet bool `yaml:"omit_subnet,omitempty" toml:",omitempty" json:",omitempty"` // DisableAAAA indicates that this [Resolver] will discard AAAA entries DisableAAAA bool `yaml:"disable_aaaa,omitempty" toml:",omitempty" json:",omitempty"` // Iterative indicates that this [Resolver] will go straight to the DNS // root servers and ask the authoritative servers for the answers. Iterative bool `yaml:",omitempty" toml:",omitempty" json:",omitempty"` // IterativeMaxRR indicates the maximum number of glue records the Iterative Resolver // will cache. IterativeMaxRR uint `yaml:",omitempty" toml:",omitempty" json:",omitempty"` // Recursive indicates that this [Resolver] will ask servers to perform // recursive lookups. Recursive bool `yaml:",omitempty" toml:",omitempty" json:",omitempty"` // Servers is a list of DNS servers to use for forwarding or iterative resolution. // If this [Resolver] is designated as iterative and no servers are provided, // a built-in list of root DNS servers will be used. Servers []string `yaml:",omitempty" toml:",omitempty" json:",omitempty"` // Suffixes indicate what domains will this [Resolver] handle. Globbing patterns allowed. Suffixes []string `yaml:",omitempty" toml:",omitempty" json:",omitempty"` // Rewrites is a list of query name rewrites to be done by this [Resolver]. Rewrites []RewriteConfig `yaml:",omitempty" toml:",omitempty" json:",omitempty"` }
Config describes a Resolver.
func (*Config) SetDefaults ¶ added in v0.0.8
func (rc *Config) SetDefaults()
SetDefaults fills gaps in the Config.
type Options ¶ added in v0.0.4
type Options struct { Logger slog.Logger SingleFlight time.Duration `default:"1s"` TLSConfig *tls.Config }
Options contains information used to assemble all [Resolver]s.
func (*Options) NewClient ¶ added in v0.0.4
NewClient uses the Options to create a new dns.Client.
func (*Options) SetDefaults ¶ added in v0.0.4
func (opts *Options) SetDefaults()
SetDefaults fills any gap in the Options.
type Resolver ¶
type Resolver struct { resolver.Exchanger Next resolver.Exchanger // contains filtered or unexported fields }
Resolver is a custom resolver.Exchanger.
type RewriteConfig ¶
type RewriteConfig struct { // From is a globbing pattern to match and capture. From string `yaml:",omitempty" toml:",omitempty" json:",omitempty"` // To is the rewrite template for entries that match the `From` pattern. To string `yaml:",omitempty" toml:",omitempty" json:",omitempty"` // Final indicates that entries matching this From shouldn't continue // to the next rewrite rule. Final bool }
RewriteConfig describes an expression used to alter a request.
Click to show internal directories.
Click to hide internal directories.