mirror of
https://github.com/klzgrad/naiveproxy.git
synced 2025-02-26 20:03:26 +03:00
163 lines
6.3 KiB
C++
163 lines
6.3 KiB
C++
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#ifndef NET_DNS_HOST_RESOLVER_PROC_H_
|
|
#define NET_DNS_HOST_RESOLVER_PROC_H_
|
|
|
|
#include <string>
|
|
|
|
#include "base/macros.h"
|
|
#include "base/memory/ref_counted.h"
|
|
#include "base/time/time.h"
|
|
#include "net/base/address_family.h"
|
|
#include "net/base/net_export.h"
|
|
|
|
namespace net {
|
|
|
|
class AddressList;
|
|
|
|
// Interface for a getaddrinfo()-like procedure. This is used by unit-tests
|
|
// to control the underlying resolutions in HostResolverManager.
|
|
// HostResolverProcs can be chained together; they fallback to the next
|
|
// procedure in the chain by calling ResolveUsingPrevious(). Unless
|
|
// `allow_fallback_to_system_or_default` is set to false, `default_proc_`
|
|
// (set via SetDefault()) is added to the end of the chain and the actual system
|
|
// resolver acts as the final fallback after the default proc.
|
|
//
|
|
// Note that implementations of HostResolverProc *MUST BE THREADSAFE*, since
|
|
// the HostResolver implementation using them can be multi-threaded.
|
|
class NET_EXPORT HostResolverProc
|
|
: public base::RefCountedThreadSafe<HostResolverProc> {
|
|
public:
|
|
explicit HostResolverProc(HostResolverProc* previous,
|
|
bool allow_fallback_to_system_or_default = true);
|
|
|
|
// Resolves |host| to an address list, restricting the results to addresses
|
|
// in |address_family|. If successful returns OK and fills |addrlist| with
|
|
// a list of socket addresses. Otherwise returns a network error code, and
|
|
// fills |os_error| with a more specific error if it was non-NULL.
|
|
virtual int Resolve(const std::string& host,
|
|
AddressFamily address_family,
|
|
HostResolverFlags host_resolver_flags,
|
|
AddressList* addrlist,
|
|
int* os_error) = 0;
|
|
|
|
protected:
|
|
friend class base::RefCountedThreadSafe<HostResolverProc>;
|
|
|
|
virtual ~HostResolverProc();
|
|
|
|
// Asks the fallback procedure (if set) to do the resolve.
|
|
int ResolveUsingPrevious(const std::string& host,
|
|
AddressFamily address_family,
|
|
HostResolverFlags host_resolver_flags,
|
|
AddressList* addrlist,
|
|
int* os_error);
|
|
|
|
private:
|
|
friend class HostResolverManager;
|
|
friend class MockHostResolverBase;
|
|
friend class ScopedDefaultHostResolverProc;
|
|
|
|
// Sets the previous procedure in the chain. Aborts if this would result in a
|
|
// cycle.
|
|
void SetPreviousProc(HostResolverProc* proc);
|
|
|
|
// Sets the last procedure in the chain, i.e. appends |proc| to the end of the
|
|
// current chain. Aborts if this would result in a cycle.
|
|
void SetLastProc(HostResolverProc* proc);
|
|
|
|
// Returns the last procedure in the chain starting at |proc|. Will return
|
|
// NULL iff |proc| is NULL.
|
|
static HostResolverProc* GetLastProc(HostResolverProc* proc);
|
|
|
|
// Sets the default host resolver procedure that is used by
|
|
// HostResolverManager. This can be used through ScopedDefaultHostResolverProc
|
|
// to set a catch-all DNS block in unit-tests (individual tests should use
|
|
// MockHostResolver to prevent hitting the network).
|
|
static HostResolverProc* SetDefault(HostResolverProc* proc);
|
|
static HostResolverProc* GetDefault();
|
|
|
|
bool allow_fallback_to_system_;
|
|
scoped_refptr<HostResolverProc> previous_proc_;
|
|
static HostResolverProc* default_proc_;
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(HostResolverProc);
|
|
};
|
|
|
|
// Resolves |host| to an address list, using the system's default host resolver.
|
|
// (i.e. this calls out to getaddrinfo()). If successful returns OK and fills
|
|
// |addrlist| with a list of socket addresses. Otherwise returns a
|
|
// network error code, and fills |os_error| with a more specific error if it
|
|
// was non-NULL.
|
|
NET_EXPORT_PRIVATE int SystemHostResolverCall(
|
|
const std::string& host,
|
|
AddressFamily address_family,
|
|
HostResolverFlags host_resolver_flags,
|
|
AddressList* addrlist,
|
|
int* os_error);
|
|
|
|
// Wraps call to SystemHostResolverCall as an instance of HostResolverProc.
|
|
class NET_EXPORT_PRIVATE SystemHostResolverProc : public HostResolverProc {
|
|
public:
|
|
SystemHostResolverProc();
|
|
int Resolve(const std::string& hostname,
|
|
AddressFamily address_family,
|
|
HostResolverFlags host_resolver_flags,
|
|
AddressList* addr_list,
|
|
int* os_error) override;
|
|
|
|
protected:
|
|
~SystemHostResolverProc() override;
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(SystemHostResolverProc);
|
|
};
|
|
|
|
// Parameters for customizing HostResolverProc behavior in HostResolvers.
|
|
//
|
|
// |resolver_proc| is used to perform the actual resolves; it must be
|
|
// thread-safe since it may be run from multiple worker threads. If
|
|
// |resolver_proc| is NULL then the default host resolver procedure is
|
|
// used (which is SystemHostResolverProc except if overridden).
|
|
//
|
|
// For each attempt, we could start another attempt if host is not resolved
|
|
// within |unresponsive_delay| time. We keep attempting to resolve the host
|
|
// for |max_retry_attempts|. For every retry attempt, we grow the
|
|
// |unresponsive_delay| by the |retry_factor| amount (that is retry interval
|
|
// is multiplied by the retry factor each time). Once we have retried
|
|
// |max_retry_attempts|, we give up on additional attempts.
|
|
//
|
|
struct NET_EXPORT_PRIVATE ProcTaskParams {
|
|
// Default delay between calls to the system resolver for the same hostname.
|
|
// (Can be overridden by field trial.)
|
|
static const base::TimeDelta kDnsDefaultUnresponsiveDelay;
|
|
|
|
// Sets up defaults.
|
|
ProcTaskParams(HostResolverProc* resolver_proc, size_t max_retry_attempts);
|
|
|
|
ProcTaskParams(const ProcTaskParams& other);
|
|
|
|
~ProcTaskParams();
|
|
|
|
// The procedure to use for resolving host names. This will be NULL, except
|
|
// in the case of unit-tests which inject custom host resolving behaviors.
|
|
scoped_refptr<HostResolverProc> resolver_proc;
|
|
|
|
// Maximum number retry attempts to resolve the hostname.
|
|
// Pass HostResolver::Options::kDefaultRetryAttempts to choose a default
|
|
// value.
|
|
size_t max_retry_attempts;
|
|
|
|
// This is the limit after which we make another attempt to resolve the host
|
|
// if the worker thread has not responded yet.
|
|
base::TimeDelta unresponsive_delay;
|
|
|
|
// Factor to grow |unresponsive_delay| when we re-re-try.
|
|
uint32_t retry_factor;
|
|
};
|
|
|
|
} // namespace net
|
|
|
|
#endif // NET_DNS_HOST_RESOLVER_PROC_H_
|