15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved.
25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be
35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file.
45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#ifndef NET_DNS_DNS_HOSTS_H_
65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#define NET_DNS_DNS_HOSTS_H_
75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <map>
95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <string>
105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <utility>
115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <vector>
125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
137dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch#include "base/basictypes.h"
147dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch#include "base/containers/hash_tables.h"
152a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "base/files/file_path.h"
165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "net/base/address_family.h"
175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "net/base/net_export.h"
185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "net/base/net_util.h"  // can't forward-declare IPAddressNumber
195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace net {
217dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch  typedef std::pair<std::string, AddressFamily> DnsHostsKey;
227dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch};
237dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch
247dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdochnamespace BASE_HASH_NAMESPACE {
257dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch#if defined(COMPILER_GCC)
267dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch
277dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdochtemplate<>
287dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdochstruct hash<net::DnsHostsKey> {
297dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch  std::size_t operator()(const net::DnsHostsKey& key) const {
307dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch    hash<base::StringPiece> string_piece_hash;
317dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch    return string_piece_hash(key.first) + key.second;
327dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch  }
337dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch};
347dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch
357dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch#elif defined(COMPILER_MSVC)
367dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch
377dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdochinline size_t hash_value(const net::DnsHostsKey& key) {
387dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch  return hash_value(key.first) + key.second;
397dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch}
407dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch
417dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch#endif  // COMPILER
427dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch
437dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch}  // namespace BASE_HASH_NAMESPACE
447dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch
457dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdochnamespace net {
465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
475f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)// There are OS-specific variations in how commas in the hosts file behave.
485f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)enum ParseHostsCommaMode {
495f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)  // Comma is treated as part of a hostname:
505f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)  // "127.0.0.1 foo,bar" parses as "foo,bar" mapping to "127.0.0.1".
515f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)  PARSE_HOSTS_COMMA_IS_TOKEN,
525f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)
535f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)  // Comma is treated as a hostname separator:
545f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)  // "127.0.0.1 foo,bar" parses as "foo" and "bar" both mapping to "127.0.0.1".
555f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)  PARSE_HOSTS_COMMA_IS_WHITESPACE,
565f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)};
575f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)
585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Parsed results of a Hosts file.
595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)//
605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Although Hosts files map IP address to a list of domain names, for name
615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// resolution the desired mapping direction is: domain name to IP address.
625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// When parsing Hosts, we apply the "first hit" rule as Windows and glibc do.
635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// With a Hosts file of:
645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// 300.300.300.300 localhost # bad ip
655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// 127.0.0.1 localhost
665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// 10.0.0.1 localhost
675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// The expected resolution of localhost is 127.0.0.1.
687dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch#if !defined(OS_ANDROID)
697dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdochtypedef base::hash_map<DnsHostsKey, IPAddressNumber> DnsHosts;
707dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch#else
717dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch// Android's hash_map doesn't support ==, so fall back to map.  (Chromium on
727dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch// Android doesn't use the built-in DNS resolver anyway, so it's irrelevant.)
735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)typedef std::map<DnsHostsKey, IPAddressNumber> DnsHosts;
747dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch#endif
755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Parses |contents| (as read from /etc/hosts or equivalent) and stores results
775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// in |dns_hosts|. Invalid lines are ignored (as in most implementations).
785f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)// Overrides the OS-specific default handling of commas, so unittests can test
795f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)// both modes.
805f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)void NET_EXPORT_PRIVATE ParseHostsWithCommaModeForTesting(
815f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)    const std::string& contents,
825f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)    DnsHosts* dns_hosts,
835f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)    ParseHostsCommaMode comma_mode);
845f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)
855f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)// Parses |contents| (as read from /etc/hosts or equivalent) and stores results
865f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)// in |dns_hosts|. Invalid lines are ignored (as in most implementations).
875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void NET_EXPORT_PRIVATE ParseHosts(const std::string& contents,
885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                                   DnsHosts* dns_hosts);
895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// As above but reads the file pointed to by |path|.
912a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)bool NET_EXPORT_PRIVATE ParseHostsFile(const base::FilePath& path,
925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                                       DnsHosts* dns_hosts);
935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}  // namespace net
975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#endif  // NET_DNS_DNS_HOSTS_H_
995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
100