566c6b246a
This diff addresses another point of https://github.com/ooni/probe/issues/1956: > - [ ] observe that we're still using a bunch of private interfaces for common interfaces such as the `Dialer`, so we can get rid of these private interfaces and always use the ones in `model`, which allows us to remove a bunch of legacy wrappers Additional cleanups may still be possible. The more I cleanup, the more I see there's extra legacy code we can dispose of (which seems good?).
50 lines
1.0 KiB
Go
50 lines
1.0 KiB
Go
package resolver
|
|
|
|
import (
|
|
"context"
|
|
"sync"
|
|
|
|
"github.com/ooni/probe-cli/v3/internal/model"
|
|
)
|
|
|
|
// CacheResolver is a resolver that caches successful replies.
|
|
type CacheResolver struct {
|
|
ReadOnly bool
|
|
model.Resolver
|
|
mu sync.Mutex
|
|
cache map[string][]string
|
|
}
|
|
|
|
// LookupHost implements Resolver.LookupHost
|
|
func (r *CacheResolver) LookupHost(
|
|
ctx context.Context, hostname string) ([]string, error) {
|
|
if entry := r.Get(hostname); entry != nil {
|
|
return entry, nil
|
|
}
|
|
entry, err := r.Resolver.LookupHost(ctx, hostname)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if r.ReadOnly == false {
|
|
r.Set(hostname, entry)
|
|
}
|
|
return entry, nil
|
|
}
|
|
|
|
// Get gets the currently configured entry for domain, or nil
|
|
func (r *CacheResolver) Get(domain string) []string {
|
|
r.mu.Lock()
|
|
defer r.mu.Unlock()
|
|
return r.cache[domain]
|
|
}
|
|
|
|
// Set allows to pre-populate the cache
|
|
func (r *CacheResolver) Set(domain string, addresses []string) {
|
|
r.mu.Lock()
|
|
if r.cache == nil {
|
|
r.cache = make(map[string][]string)
|
|
}
|
|
r.cache[domain] = addresses
|
|
r.mu.Unlock()
|
|
}
|