2021-03-03 11:28:39 +01:00
|
|
|
package sessionresolver
|
|
|
|
|
2022-06-08 22:01:51 +02:00
|
|
|
//
|
|
|
|
// Actual lookup code
|
|
|
|
//
|
|
|
|
|
2021-03-03 11:28:39 +01:00
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"time"
|
2022-06-08 14:06:22 +02:00
|
|
|
|
|
|
|
"github.com/ooni/probe-cli/v3/internal/model"
|
2021-03-03 11:28:39 +01:00
|
|
|
)
|
|
|
|
|
2022-06-08 14:06:22 +02:00
|
|
|
// defaultTimeLimitedLookupTimeout is the default timeout the code should
|
|
|
|
// pass to the timeLimitedLookup function.
|
|
|
|
//
|
|
|
|
// This algorithm is similar to Firefox using TRR2 mode. See:
|
|
|
|
// https://wiki.mozilla.org/Trusted_Recursive_Resolver#DNS-over-HTTPS_Prefs_in_Firefox
|
|
|
|
//
|
|
|
|
// We use a higher timeout than Firefox's timeout (1.5s) to be on the safe side
|
|
|
|
// and therefore see to use DoH more often.
|
|
|
|
const defaultTimeLimitedLookupTimeout = 4 * time.Second
|
2021-03-03 11:28:39 +01:00
|
|
|
|
2022-06-08 14:06:22 +02:00
|
|
|
// timeLimitedLookup performs a time-limited lookup using the given re.
|
|
|
|
func timeLimitedLookup(ctx context.Context, re model.Resolver, hostname string) ([]string, error) {
|
|
|
|
return timeLimitedLookupWithTimeout(ctx, re, hostname, defaultTimeLimitedLookupTimeout)
|
2021-03-03 11:28:39 +01:00
|
|
|
}
|
|
|
|
|
2022-06-08 14:06:22 +02:00
|
|
|
// timeLimitedLookupWithTimeout is like timeLimitedLookup but with explicit timeout.
|
|
|
|
func timeLimitedLookupWithTimeout(ctx context.Context, re model.Resolver,
|
|
|
|
hostname string, timeout time.Duration) ([]string, error) {
|
2022-06-08 15:06:15 +02:00
|
|
|
// In https://github.com/ooni/probe-cli/pull/807, I modified this code to
|
|
|
|
// run in a background goroutine and this resulted in a data race, see
|
|
|
|
// https://github.com/ooni/probe/issues/2135#issuecomment-1149840579. While
|
|
|
|
// I could not reproduce the data race in a simple way, the race itself
|
|
|
|
// seems to happen inside the http3 package. For now, I am going to revert
|
|
|
|
// the change causing the race and I'll investigate later.
|
2022-06-08 14:06:22 +02:00
|
|
|
ctx, cancel := context.WithTimeout(ctx, timeout)
|
2021-03-03 11:28:39 +01:00
|
|
|
defer cancel()
|
2022-06-08 15:06:15 +02:00
|
|
|
return re.LookupHost(ctx, hostname)
|
2021-03-03 11:28:39 +01:00
|
|
|
}
|