blob: 220fcc60a1068c1ab5a1c53bb71e175ebafa1ed0 [file] [log] [blame]
// Copyright 2018 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef NET_DNS_PUBLIC_HOST_RESOLVER_SOURCE_H_
#define NET_DNS_PUBLIC_HOST_RESOLVER_SOURCE_H_
#include <iterator>
namespace net {
// Enumeration to specify the allowed results source for HostResolver
// requests.
enum class HostResolverSource {
// Resolver will pick an appropriate source. Results could come from DNS,
// MulticastDNS, HOSTS file, etc.
ANY,
// Results will only be retrieved from the system or OS, eg via the
// getaddrinfo() system call.
SYSTEM,
// Results will only come from DNS queries.
DNS,
// Results will only come from Multicast DNS queries.
MULTICAST_DNS,
// No external sources will be used. Results will only come from fast local
// sources that are available no matter the source setting, e.g. cache, hosts
// file, IP literal resolution, etc. Resolves with this setting are guaranteed
// to finish synchronously. Resolves with this settings will return
// ERR_NAME_NOT_RESOLVED if an asynchronous IPv6 reachability probe needs to
// be done.
LOCAL_ONLY,
MAX = LOCAL_ONLY
};
const HostResolverSource kHostResolverSources[] = {
HostResolverSource::ANY, HostResolverSource::SYSTEM,
HostResolverSource::DNS, HostResolverSource::MULTICAST_DNS,
HostResolverSource::LOCAL_ONLY};
static_assert(
std::size(kHostResolverSources) ==
static_cast<unsigned>(HostResolverSource::MAX) + 1,
"All HostResolverSource values should be in kHostResolverSources.");
} // namespace net
#endif // NET_DNS_PUBLIC_HOST_RESOLVER_SOURCE_H_