// Copyright (c) 2011 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_BASE_MAPPED_HOST_RESOLVER_H_ #define NET_BASE_MAPPED_HOST_RESOLVER_H_ #pragma once #include #include "base/memory/scoped_ptr.h" #include "net/base/host_mapping_rules.h" #include "net/base/host_resolver.h" namespace net { // This class wraps an existing HostResolver instance, but modifies the // request before passing it off to |impl|. This is different from // MockHostResolver which does the remapping at the HostResolverProc // layer, so it is able to preserve the effectiveness of the cache. class MappedHostResolver : public HostResolver { public: // Creates a MappedHostResolver that forwards all of its requests through // |impl|. It takes ownership of |impl|. explicit MappedHostResolver(HostResolver* impl); virtual ~MappedHostResolver(); // Adds a rule to this mapper. The format of the rule can be one of: // // "MAP" [":" ] // "EXCLUDE" // // The can be either a hostname, or an IP address literal. // // Returns true if the rule was successfully parsed and added. bool AddRuleFromString(const std::string& rule_string) { return rules_.AddRuleFromString(rule_string); } // Takes a comma separated list of rules, and assigns them to this resolver. void SetRulesFromString(const std::string& rules_string) { rules_.SetRulesFromString(rules_string); } // HostResolver methods: virtual int Resolve(const RequestInfo& info, AddressList* addresses, CompletionCallback* callback, RequestHandle* out_req, const BoundNetLog& net_log); virtual void CancelRequest(RequestHandle req); virtual void AddObserver(Observer* observer); virtual void RemoveObserver(Observer* observer); virtual HostResolverImpl* GetAsHostResolverImpl(); private: scoped_ptr impl_; HostMappingRules rules_; }; } // namespace net #endif // NET_BASE_MAPPED_HOST_RESOLVER_H_