ce052b665e
This diff has been extracted from eb0bf38957
.
See https://github.com/ooni/probe/issues/2096.
While there, skip the broken tests caused by issue
https://github.com/ooni/probe/issues/2098.
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 {
|
|
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()
|
|
}
|