Home | History | Annotate | Download | only in dns
      1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 #ifndef NET_DNS_SINGLE_REQUEST_HOST_RESOLVER_H_
      6 #define NET_DNS_SINGLE_REQUEST_HOST_RESOLVER_H_
      7 
      8 #include "base/basictypes.h"
      9 
     10 #include "net/base/completion_callback.h"
     11 #include "net/base/net_export.h"
     12 #include "net/base/request_priority.h"
     13 #include "net/dns/host_resolver.h"
     14 
     15 namespace net {
     16 
     17 class AddressList;
     18 class BoundNetLog;
     19 
     20 // This class represents the task of resolving a hostname (or IP address
     21 // literal) to an AddressList object.  It wraps HostResolver to resolve only a
     22 // single hostname at a time and cancels this request when going out of scope.
     23 class NET_EXPORT SingleRequestHostResolver {
     24  public:
     25   // |resolver| must remain valid for the lifetime of |this|.
     26   explicit SingleRequestHostResolver(HostResolver* resolver);
     27 
     28   // If a completion callback is pending when the resolver is destroyed, the
     29   // host resolution is cancelled, and the completion callback will not be
     30   // called.
     31   ~SingleRequestHostResolver();
     32 
     33   // Resolves the given hostname (or IP address literal), filling out the
     34   // |addresses| object upon success. See HostResolver::Resolve() for details.
     35   int Resolve(const HostResolver::RequestInfo& info,
     36               RequestPriority priority,
     37               AddressList* addresses,
     38               const CompletionCallback& callback,
     39               const BoundNetLog& net_log);
     40 
     41   // Cancels the in-progress request, if any. This prevents the callback
     42   // from being invoked. Resolve() can be called again after cancelling.
     43   void Cancel();
     44 
     45  private:
     46   // Callback for when the request to |resolver_| completes, so we dispatch
     47   // to the user's callback.
     48   void OnResolveCompletion(int result);
     49 
     50   // The actual host resolver that will handle the request.
     51   HostResolver* const resolver_;
     52 
     53   // The current request (if any).
     54   HostResolver::RequestHandle cur_request_;
     55   CompletionCallback cur_request_callback_;
     56 
     57   // Completion callback for when request to |resolver_| completes.
     58   CompletionCallback callback_;
     59 
     60   DISALLOW_COPY_AND_ASSIGN(SingleRequestHostResolver);
     61 };
     62 
     63 }  // namespace net
     64 
     65 #endif  // NET_DNS_SINGLE_REQUEST_HOST_RESOLVER_H_
     66