2021-03-28 22:21:23 +03:00
|
|
|
package main
|
|
|
|
|
|
|
|
|
|
import (
|
2024-08-01 12:44:23 +03:00
|
|
|
"context"
|
|
|
|
|
"fmt"
|
|
|
|
|
"net/netip"
|
2024-08-01 12:01:24 +03:00
|
|
|
"time"
|
|
|
|
|
|
2021-03-28 22:21:23 +03:00
|
|
|
"github.com/AdguardTeam/dnsproxy/upstream"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type Resolver struct {
|
2024-08-01 12:44:23 +03:00
|
|
|
resolvers upstream.ParallelResolver
|
|
|
|
|
timeout time.Duration
|
2021-03-28 22:21:23 +03:00
|
|
|
}
|
|
|
|
|
|
2024-08-01 12:44:23 +03:00
|
|
|
func NewResolver(addresses []string, timeout time.Duration) (*Resolver, error) {
|
|
|
|
|
resolvers := make([]upstream.Resolver, 0, len(addresses))
|
|
|
|
|
opts := &upstream.Options{
|
|
|
|
|
Timeout: timeout,
|
2021-03-28 22:21:23 +03:00
|
|
|
}
|
2024-08-01 12:44:23 +03:00
|
|
|
for _, addr := range addresses {
|
|
|
|
|
u, err := upstream.AddressToUpstream(addr, opts)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, fmt.Errorf("unable to construct upstream resolver from string %q: %w",
|
|
|
|
|
addr, err)
|
2021-03-28 22:21:23 +03:00
|
|
|
}
|
2024-08-01 12:44:23 +03:00
|
|
|
resolvers = append(resolvers, &upstream.UpstreamResolver{Upstream: u})
|
2021-03-28 22:21:23 +03:00
|
|
|
}
|
2024-08-01 12:44:23 +03:00
|
|
|
return &Resolver{
|
|
|
|
|
resolvers: resolvers,
|
|
|
|
|
timeout: timeout,
|
|
|
|
|
}, nil
|
2021-03-28 22:21:23 +03:00
|
|
|
}
|
|
|
|
|
|
2024-08-01 12:44:23 +03:00
|
|
|
func (r *Resolver) LookupNetIP(ctx context.Context, network string, host string) (addrs []netip.Addr, err error) {
|
|
|
|
|
return r.resolvers.LookupNetIP(ctx, network, host)
|
2021-03-28 22:21:23 +03:00
|
|
|
}
|