From d3c6c11e4898207e86b018b1f244969e24019907 Mon Sep 17 00:00:00 2001 From: Simone Basso Date: Mon, 10 Jan 2022 11:53:06 +0100 Subject: [PATCH] cleanup(netx): remove the DNSClient type (#660) The DNSClient type existed because the Resolver type did not include CloseIdleConnections in its signature. Now that Resolver includes CloseIdleConnections, the DNSClient type has become unnecessary and can be safely removed. See https://github.com/ooni/probe/issues/1956. --- internal/cmd/jafar/uncensored/uncensored.go | 4 +- .../engine/experiment/urlgetter/configurer.go | 4 +- internal/engine/netx/netx.go | 50 ++++++------------- internal/engine/netx/netx_test.go | 36 +++++++------ 4 files changed, 36 insertions(+), 58 deletions(-) diff --git a/internal/cmd/jafar/uncensored/uncensored.go b/internal/cmd/jafar/uncensored/uncensored.go index 2c96072..6dab98e 100644 --- a/internal/cmd/jafar/uncensored/uncensored.go +++ b/internal/cmd/jafar/uncensored/uncensored.go @@ -17,7 +17,7 @@ import ( // Client is DNS, HTTP, and TCP client. type Client struct { - dnsClient *netx.DNSClient + dnsClient model.Resolver httpTransport model.HTTPTransport dialer model.Dialer } @@ -34,7 +34,7 @@ func NewClient(resolverURL string) (*Client, error) { return nil, err } return &Client{ - dnsClient: &configuration.DNSClient, + dnsClient: configuration.DNSClient, httpTransport: netx.NewHTTPTransport(configuration.HTTPConfig), dialer: netx.NewDialer(configuration.HTTPConfig), }, nil diff --git a/internal/engine/experiment/urlgetter/configurer.go b/internal/engine/experiment/urlgetter/configurer.go index ad405c2..4a22e3b 100644 --- a/internal/engine/experiment/urlgetter/configurer.go +++ b/internal/engine/experiment/urlgetter/configurer.go @@ -26,7 +26,7 @@ type Configurer struct { // The Configuration is the configuration for running a measurement. type Configuration struct { HTTPConfig netx.Config - DNSClient netx.DNSClient + DNSClient model.Resolver } // CloseIdleConnections will close idle connections, if needed. @@ -82,7 +82,7 @@ func (c Configurer) NewConfiguration() (Configuration, error) { return configuration, err } configuration.DNSClient = dnsclient - configuration.HTTPConfig.BaseResolver = dnsclient.Resolver + configuration.HTTPConfig.BaseResolver = dnsclient // configure TLS configuration.HTTPConfig.TLSConfig = &tls.Config{ NextProtos: []string{"h2", "http/1.1"}, diff --git a/internal/engine/netx/netx.go b/internal/engine/netx/netx.go index 1b7e822..4be37f9 100644 --- a/internal/engine/netx/netx.go +++ b/internal/engine/netx/netx.go @@ -239,20 +239,6 @@ var allTransportsInfo = map[bool]httpTransportInfo{ }, } -// DNSClient is a DNS client. It wraps a Resolver and it possibly -// also wraps an HTTP client, but only when we're using DoH. -type DNSClient struct { - model.Resolver - httpClient *http.Client -} - -// CloseIdleConnections closes idle connections, if any. -func (c DNSClient) CloseIdleConnections() { - if c.httpClient != nil { - c.httpClient.CloseIdleConnections() - } -} - // NewDNSClient creates a new DNS client. The config argument is used to // create the underlying Dialer and/or HTTP transport, if needed. The URL // argument describes the kind of client that we want to make: @@ -271,15 +257,14 @@ func (c DNSClient) CloseIdleConnections() { // // If config.ResolveSaver is not nil and we're creating an underlying // resolver where this is possible, we will also save events. -func NewDNSClient(config Config, URL string) (DNSClient, error) { +func NewDNSClient(config Config, URL string) (model.Resolver, error) { return NewDNSClientWithOverrides(config, URL, "", "", "") } // NewDNSClientWithOverrides creates a new DNS client, similar to NewDNSClient, // with the option to override the default Hostname and SNI. func NewDNSClientWithOverrides(config Config, URL, hostOverride, SNIOverride, - TLSVersion string) (DNSClient, error) { - var c DNSClient + TLSVersion string) (model.Resolver, error) { switch URL { case "doh://powerdns": URL = "https://doh.powerdns.org/" @@ -292,34 +277,32 @@ func NewDNSClientWithOverrides(config Config, URL, hostOverride, SNIOverride, } resolverURL, err := url.Parse(URL) if err != nil { - return c, err + return nil, err } config.TLSConfig = &tls.Config{ServerName: SNIOverride} if err := netxlite.ConfigureTLSVersion(config.TLSConfig, TLSVersion); err != nil { - return c, err + return nil, err } switch resolverURL.Scheme { case "system": - c.Resolver = &netxlite.ResolverSystem{} - return c, nil + return &netxlite.ResolverSystem{}, nil case "https": config.TLSConfig.NextProtos = []string{"h2", "http/1.1"} - c.httpClient = &http.Client{Transport: NewHTTPTransport(config)} + httpClient := &http.Client{Transport: NewHTTPTransport(config)} var txp model.DNSTransport = netxlite.NewDNSOverHTTPSWithHostOverride( - c.httpClient, URL, hostOverride) + httpClient, URL, hostOverride) if config.ResolveSaver != nil { txp = resolver.SaverDNSTransport{ DNSTransport: txp, Saver: config.ResolveSaver, } } - c.Resolver = netxlite.NewSerialResolver(txp) - return c, nil + return netxlite.NewSerialResolver(txp), nil case "udp": dialer := NewDialer(config) endpoint, err := makeValidEndpoint(resolverURL) if err != nil { - return c, err + return nil, err } var txp model.DNSTransport = netxlite.NewDNSOverUDP( dialer, endpoint) @@ -329,14 +312,13 @@ func NewDNSClientWithOverrides(config Config, URL, hostOverride, SNIOverride, Saver: config.ResolveSaver, } } - c.Resolver = netxlite.NewSerialResolver(txp) - return c, nil + return netxlite.NewSerialResolver(txp), nil case "dot": config.TLSConfig.NextProtos = []string{"dot"} tlsDialer := NewTLSDialer(config) endpoint, err := makeValidEndpoint(resolverURL) if err != nil { - return c, err + return nil, err } var txp model.DNSTransport = netxlite.NewDNSOverTLS( tlsDialer.DialTLSContext, endpoint) @@ -346,13 +328,12 @@ func NewDNSClientWithOverrides(config Config, URL, hostOverride, SNIOverride, Saver: config.ResolveSaver, } } - c.Resolver = netxlite.NewSerialResolver(txp) - return c, nil + return netxlite.NewSerialResolver(txp), nil case "tcp": dialer := NewDialer(config) endpoint, err := makeValidEndpoint(resolverURL) if err != nil { - return c, err + return nil, err } var txp model.DNSTransport = netxlite.NewDNSOverTCP( dialer.DialContext, endpoint) @@ -362,10 +343,9 @@ func NewDNSClientWithOverrides(config Config, URL, hostOverride, SNIOverride, Saver: config.ResolveSaver, } } - c.Resolver = netxlite.NewSerialResolver(txp) - return c, nil + return netxlite.NewSerialResolver(txp), nil default: - return c, errors.New("unsupported resolver scheme") + return nil, errors.New("unsupported resolver scheme") } } diff --git a/internal/engine/netx/netx_test.go b/internal/engine/netx/netx_test.go index 9d03a99..17117e7 100644 --- a/internal/engine/netx/netx_test.go +++ b/internal/engine/netx/netx_test.go @@ -544,10 +544,9 @@ func TestNewDNSClientInvalidURL(t *testing.T) { if err == nil || !strings.HasSuffix(err.Error(), "invalid control character in URL") { t.Fatal("not the error we expected") } - if dnsclient.Resolver != nil { + if dnsclient != nil { t.Fatal("expected nil resolver here") } - dnsclient.CloseIdleConnections() } func TestNewDNSClientUnsupportedScheme(t *testing.T) { @@ -555,10 +554,9 @@ func TestNewDNSClientUnsupportedScheme(t *testing.T) { if err == nil || err.Error() != "unsupported resolver scheme" { t.Fatal("not the error we expected") } - if dnsclient.Resolver != nil { + if dnsclient != nil { t.Fatal("expected nil resolver here") } - dnsclient.CloseIdleConnections() } func TestNewDNSClientSystemResolver(t *testing.T) { @@ -567,7 +565,7 @@ func TestNewDNSClientSystemResolver(t *testing.T) { if err != nil { t.Fatal(err) } - if _, ok := dnsclient.Resolver.(*netxlite.ResolverSystem); !ok { + if _, ok := dnsclient.(*netxlite.ResolverSystem); !ok { t.Fatal("not the resolver we expected") } dnsclient.CloseIdleConnections() @@ -579,7 +577,7 @@ func TestNewDNSClientEmpty(t *testing.T) { if err != nil { t.Fatal(err) } - if _, ok := dnsclient.Resolver.(*netxlite.ResolverSystem); !ok { + if _, ok := dnsclient.(*netxlite.ResolverSystem); !ok { t.Fatal("not the resolver we expected") } dnsclient.CloseIdleConnections() @@ -591,7 +589,7 @@ func TestNewDNSClientPowerdnsDoH(t *testing.T) { if err != nil { t.Fatal(err) } - r, ok := dnsclient.Resolver.(*netxlite.SerialResolver) + r, ok := dnsclient.(*netxlite.SerialResolver) if !ok { t.Fatal("not the resolver we expected") } @@ -607,7 +605,7 @@ func TestNewDNSClientGoogleDoH(t *testing.T) { if err != nil { t.Fatal(err) } - r, ok := dnsclient.Resolver.(*netxlite.SerialResolver) + r, ok := dnsclient.(*netxlite.SerialResolver) if !ok { t.Fatal("not the resolver we expected") } @@ -623,7 +621,7 @@ func TestNewDNSClientCloudflareDoH(t *testing.T) { if err != nil { t.Fatal(err) } - r, ok := dnsclient.Resolver.(*netxlite.SerialResolver) + r, ok := dnsclient.(*netxlite.SerialResolver) if !ok { t.Fatal("not the resolver we expected") } @@ -640,7 +638,7 @@ func TestNewDNSClientCloudflareDoHSaver(t *testing.T) { if err != nil { t.Fatal(err) } - r, ok := dnsclient.Resolver.(*netxlite.SerialResolver) + r, ok := dnsclient.(*netxlite.SerialResolver) if !ok { t.Fatal("not the resolver we expected") } @@ -660,7 +658,7 @@ func TestNewDNSClientUDP(t *testing.T) { if err != nil { t.Fatal(err) } - r, ok := dnsclient.Resolver.(*netxlite.SerialResolver) + r, ok := dnsclient.(*netxlite.SerialResolver) if !ok { t.Fatal("not the resolver we expected") } @@ -677,7 +675,7 @@ func TestNewDNSClientUDPDNSSaver(t *testing.T) { if err != nil { t.Fatal(err) } - r, ok := dnsclient.Resolver.(*netxlite.SerialResolver) + r, ok := dnsclient.(*netxlite.SerialResolver) if !ok { t.Fatal("not the resolver we expected") } @@ -697,7 +695,7 @@ func TestNewDNSClientTCP(t *testing.T) { if err != nil { t.Fatal(err) } - r, ok := dnsclient.Resolver.(*netxlite.SerialResolver) + r, ok := dnsclient.(*netxlite.SerialResolver) if !ok { t.Fatal("not the resolver we expected") } @@ -718,7 +716,7 @@ func TestNewDNSClientTCPDNSSaver(t *testing.T) { if err != nil { t.Fatal(err) } - r, ok := dnsclient.Resolver.(*netxlite.SerialResolver) + r, ok := dnsclient.(*netxlite.SerialResolver) if !ok { t.Fatal("not the resolver we expected") } @@ -742,7 +740,7 @@ func TestNewDNSClientDoT(t *testing.T) { if err != nil { t.Fatal(err) } - r, ok := dnsclient.Resolver.(*netxlite.SerialResolver) + r, ok := dnsclient.(*netxlite.SerialResolver) if !ok { t.Fatal("not the resolver we expected") } @@ -763,7 +761,7 @@ func TestNewDNSClientDoTDNSSaver(t *testing.T) { if err != nil { t.Fatal(err) } - r, ok := dnsclient.Resolver.(*netxlite.SerialResolver) + r, ok := dnsclient.(*netxlite.SerialResolver) if !ok { t.Fatal("not the resolver we expected") } @@ -787,7 +785,7 @@ func TestNewDNSCLientDoTWithoutPort(t *testing.T) { if err != nil { t.Fatal(err) } - if c.Resolver.Address() != "8.8.8.8:853" { + if c.Address() != "8.8.8.8:853" { t.Fatal("expected default port to be added") } } @@ -798,7 +796,7 @@ func TestNewDNSCLientTCPWithoutPort(t *testing.T) { if err != nil { t.Fatal(err) } - if c.Resolver.Address() != "8.8.8.8:53" { + if c.Address() != "8.8.8.8:53" { t.Fatal("expected default port to be added") } } @@ -809,7 +807,7 @@ func TestNewDNSCLientUDPWithoutPort(t *testing.T) { if err != nil { t.Fatal(err) } - if c.Resolver.Address() != "8.8.8.8:53" { + if c.Address() != "8.8.8.8:53" { t.Fatal("expected default port to be added") } }