OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef NET_PROXY_DHCP_PROXY_SCRIPT_FETCHER_WIN_H_ | 5 #ifndef NET_PROXY_DHCP_PROXY_SCRIPT_FETCHER_WIN_H_ |
6 #define NET_PROXY_DHCP_PROXY_SCRIPT_FETCHER_WIN_H_ | 6 #define NET_PROXY_DHCP_PROXY_SCRIPT_FETCHER_WIN_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include <set> | 9 #include <set> |
10 #include <string> | 10 #include <string> |
(...skipping 17 matching lines...) Expand all Loading... |
28 public base::SupportsWeakPtr<DhcpProxyScriptFetcherWin>, | 28 public base::SupportsWeakPtr<DhcpProxyScriptFetcherWin>, |
29 NON_EXPORTED_BASE(public base::NonThreadSafe) { | 29 NON_EXPORTED_BASE(public base::NonThreadSafe) { |
30 public: | 30 public: |
31 // Creates a DhcpProxyScriptFetcherWin that issues requests through | 31 // Creates a DhcpProxyScriptFetcherWin that issues requests through |
32 // |url_request_context|. |url_request_context| must remain valid for | 32 // |url_request_context|. |url_request_context| must remain valid for |
33 // the lifetime of DhcpProxyScriptFetcherWin. | 33 // the lifetime of DhcpProxyScriptFetcherWin. |
34 explicit DhcpProxyScriptFetcherWin(URLRequestContext* url_request_context); | 34 explicit DhcpProxyScriptFetcherWin(URLRequestContext* url_request_context); |
35 virtual ~DhcpProxyScriptFetcherWin(); | 35 virtual ~DhcpProxyScriptFetcherWin(); |
36 | 36 |
37 // DhcpProxyScriptFetcher implementation. | 37 // DhcpProxyScriptFetcher implementation. |
38 int Fetch(string16* utf16_text, OldCompletionCallback* callback) OVERRIDE; | 38 int Fetch(string16* utf16_text, |
| 39 const net::CompletionCallback& callback) OVERRIDE; |
39 void Cancel() OVERRIDE; | 40 void Cancel() OVERRIDE; |
40 const GURL& GetPacURL() const OVERRIDE; | 41 const GURL& GetPacURL() const OVERRIDE; |
41 std::string GetFetcherName() const OVERRIDE; | 42 std::string GetFetcherName() const OVERRIDE; |
42 | 43 |
43 // Sets |adapter_names| to contain the name of each network adapter on | 44 // Sets |adapter_names| to contain the name of each network adapter on |
44 // this machine that has DHCP enabled and is not a loop-back adapter. Returns | 45 // this machine that has DHCP enabled and is not a loop-back adapter. Returns |
45 // false on error. | 46 // false on error. |
46 static bool GetCandidateAdapterNames(std::set<std::string>* adapter_names); | 47 static bool GetCandidateAdapterNames(std::set<std::string>* adapter_names); |
47 | 48 |
48 protected: | 49 protected: |
(...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
131 | 132 |
132 // Current state of this state machine. | 133 // Current state of this state machine. |
133 State state_; | 134 State state_; |
134 | 135 |
135 // Vector, in Windows' network adapter preference order, of | 136 // Vector, in Windows' network adapter preference order, of |
136 // DhcpProxyScriptAdapterFetcher objects that are or were attempting | 137 // DhcpProxyScriptAdapterFetcher objects that are or were attempting |
137 // to fetch a PAC file based on DHCP configuration. | 138 // to fetch a PAC file based on DHCP configuration. |
138 typedef ScopedVector<DhcpProxyScriptAdapterFetcher> FetcherVector; | 139 typedef ScopedVector<DhcpProxyScriptAdapterFetcher> FetcherVector; |
139 FetcherVector fetchers_; | 140 FetcherVector fetchers_; |
140 | 141 |
141 // Callback invoked when any fetcher completes. | |
142 OldCompletionCallbackImpl<DhcpProxyScriptFetcherWin> fetcher_callback_; | |
143 | |
144 // Number of fetchers we are waiting for. | 142 // Number of fetchers we are waiting for. |
145 int num_pending_fetchers_; | 143 int num_pending_fetchers_; |
146 | 144 |
147 // Lets our client know we're done. Not valid in states START or DONE. | 145 // Lets our client know we're done. Not valid in states START or DONE. |
148 OldCompletionCallback* client_callback_; | 146 net::CompletionCallback callback_; |
149 | 147 |
150 // Pointer to string we will write results to. Not valid in states | 148 // Pointer to string we will write results to. Not valid in states |
151 // START and DONE. | 149 // START and DONE. |
152 string16* destination_string_; | 150 string16* destination_string_; |
153 | 151 |
154 // PAC URL retrieved from DHCP, if any. Valid only in state STATE_DONE. | 152 // PAC URL retrieved from DHCP, if any. Valid only in state STATE_DONE. |
155 GURL pac_url_; | 153 GURL pac_url_; |
156 | 154 |
157 base::OneShotTimer<DhcpProxyScriptFetcherWin> wait_timer_; | 155 base::OneShotTimer<DhcpProxyScriptFetcherWin> wait_timer_; |
158 | 156 |
159 scoped_refptr<URLRequestContext> url_request_context_; | 157 scoped_refptr<URLRequestContext> url_request_context_; |
160 | 158 |
161 // NULL or the AdapterQuery currently in flight. | 159 // NULL or the AdapterQuery currently in flight. |
162 scoped_refptr<AdapterQuery> last_query_; | 160 scoped_refptr<AdapterQuery> last_query_; |
163 | 161 |
164 // Time |Fetch()| was last called, 0 if never. | 162 // Time |Fetch()| was last called, 0 if never. |
165 base::TimeTicks fetch_start_time_; | 163 base::TimeTicks fetch_start_time_; |
166 | 164 |
167 DISALLOW_IMPLICIT_CONSTRUCTORS(DhcpProxyScriptFetcherWin); | 165 DISALLOW_IMPLICIT_CONSTRUCTORS(DhcpProxyScriptFetcherWin); |
168 }; | 166 }; |
169 | 167 |
170 } // namespace net | 168 } // namespace net |
171 | 169 |
172 #endif // NET_PROXY_DHCP_PROXY_SCRIPT_FETCHER_WIN_H_ | 170 #endif // NET_PROXY_DHCP_PROXY_SCRIPT_FETCHER_WIN_H_ |
OLD | NEW |