Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(256)

Side by Side Diff: net/proxy/proxy_script_decider.h

Issue 8896019: Refactor: Extract "InitProxyResolver" to "ProxyScriptDecider". (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: do another sync since commitbot failed... Created 9 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « net/proxy/init_proxy_resolver_unittest.cc ('k') | net/proxy/proxy_script_decider.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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_INIT_PROXY_RESOLVER_H_ 5 #ifndef NET_PROXY_SCRIPT_DECIDER_H
6 #define NET_PROXY_INIT_PROXY_RESOLVER_H_ 6 #define NET_PROXY_SCRIPT_DECIDER_H
7 #pragma once 7 #pragma once
8 8
9 #include <vector> 9 #include <vector>
10 10
11 #include "base/memory/scoped_ptr.h" 11 #include "base/memory/scoped_ptr.h"
12 #include "base/string16.h" 12 #include "base/string16.h"
13 #include "base/time.h" 13 #include "base/time.h"
14 #include "base/timer.h" 14 #include "base/timer.h"
15 #include "googleurl/src/gurl.h" 15 #include "googleurl/src/gurl.h"
16 #include "net/base/completion_callback.h" 16 #include "net/base/completion_callback.h"
17 #include "net/base/net_export.h" 17 #include "net/base/net_export.h"
18 #include "net/base/net_log.h" 18 #include "net/base/net_log.h"
19 #include "net/proxy/proxy_config.h"
20 #include "net/proxy/proxy_resolver.h"
19 21
20 namespace net { 22 namespace net {
21 23
22 class DhcpProxyScriptFetcher; 24 class DhcpProxyScriptFetcher;
23 class NetLogParameter; 25 class NetLogParameter;
24 class ProxyConfig;
25 class ProxyResolver; 26 class ProxyResolver;
26 class ProxyScriptFetcher; 27 class ProxyScriptFetcher;
27 28
28 // InitProxyResolver is a helper class used by ProxyService to 29 // ProxyScriptDecider is a helper class used by ProxyService to determine which
29 // initialize a ProxyResolver with the PAC script data specified 30 // PAC script to use given our proxy configuration.
30 // by a particular ProxyConfig.
31 // 31 //
32 // This involves trying to use PAC scripts in this order: 32 // This involves trying to use PAC scripts in this order:
33 // 33 //
34 // (1) WPAD (DNS) if auto-detect is on. 34 // (1) WPAD (DHCP) if auto-detect is on.
35 // (2) Custom PAC script if a URL was given. 35 // (2) WPAD (DNS) if auto-detect is on.
36 // (3) Custom PAC script if a URL was given.
36 // 37 //
37 // If no PAC script was successfully downloaded + parsed, then it fails with 38 // If no PAC script was successfully selected, then it fails with either a
38 // a network error. Otherwise the proxy resolver is left initialized with 39 // network error, or PAC_SCRIPT_FAILED (indicating it did not pass our
39 // the PAC script. 40 // validation).
40 // 41 //
41 // Deleting InitProxyResolver while Init() is in progress, will 42 // On successful completion, the fetched PAC script data can be accessed using
43 // script_data().
44 //
45 // Deleting ProxyScriptDecider while Init() is in progress, will
42 // cancel the request. 46 // cancel the request.
43 // 47 //
44 class NET_EXPORT_PRIVATE InitProxyResolver { 48 class NET_EXPORT_PRIVATE ProxyScriptDecider {
45 public: 49 public:
46 // |resolver|, |proxy_script_fetcher|, |dhcp_proxy_script_fetcher| and 50 // |proxy_script_fetcher|, |dhcp_proxy_script_fetcher| and
47 // |net_log| must remain valid for the lifespan of InitProxyResolver. 51 // |net_log| must remain valid for the lifespan of ProxyScriptDecider.
48 InitProxyResolver(ProxyResolver* resolver, 52 ProxyScriptDecider(ProxyScriptFetcher* proxy_script_fetcher,
49 ProxyScriptFetcher* proxy_script_fetcher, 53 DhcpProxyScriptFetcher* dhcp_proxy_script_fetcher,
50 DhcpProxyScriptFetcher* dhcp_proxy_script_fetcher, 54 NetLog* net_log);
51 NetLog* net_log);
52 55
53 // Aborts any in-progress request. 56 // Aborts any in-progress request.
54 ~InitProxyResolver(); 57 ~ProxyScriptDecider();
55 58
56 // Applies the PAC settings of |config| to |resolver_|. 59 // Evaluates the effective proxy settings for |config|, and downloads the
60 // associated PAC script.
57 // If |wait_delay| is positive, the initialization will pause for this 61 // If |wait_delay| is positive, the initialization will pause for this
58 // amount of time before getting started. 62 // amount of time before getting started.
59 // If |effective_config| is non-NULL, then on successful initialization of 63 // On successful completion, the "effective" proxy settings we ended up
60 // |resolver_| the "effective" proxy settings we ended up using will be 64 // deciding on will be available vial the effective_settings() accessor.
61 // written out to |*effective_config|. Note that this may differ from 65 // Note that this may differ from |config| since we will have stripped any
62 // |config| since we will have stripped any manual settings, and decided 66 // manual settings, and decided whether to use auto-detect or the custom PAC
63 // whether to use auto-detect or the custom PAC URL. Finally, if auto-detect 67 // URL. Finally, if auto-detect was used we may now have resolved that to a
64 // was used we may now have resolved that to a specific script URL. 68 // specific script URL.
65 int Init(const ProxyConfig& config, 69 int Start(const ProxyConfig& config,
66 const base::TimeDelta wait_delay, 70 const base::TimeDelta wait_delay,
67 ProxyConfig* effective_config, 71 bool fetch_pac_bytes,
68 OldCompletionCallback* callback); 72 OldCompletionCallback* callback);
73
74 const ProxyConfig& effective_config() const;
75
76 // TODO(eroman): Return a const-pointer.
77 ProxyResolverScriptData* script_data() const;
69 78
70 private: 79 private:
71 // Represents the sources from which we can get PAC files; two types of 80 // Represents the sources from which we can get PAC files; two types of
72 // auto-detect or a custom URL. 81 // auto-detect or a custom URL.
73 struct PacSource { 82 struct PacSource {
74 enum Type { 83 enum Type {
75 WPAD_DHCP, 84 WPAD_DHCP,
76 WPAD_DNS, 85 WPAD_DNS,
77 CUSTOM 86 CUSTOM
78 }; 87 };
79 88
80 PacSource(Type type, const GURL& url) 89 PacSource(Type type, const GURL& url)
81 : type(type), url(url) {} 90 : type(type), url(url) {}
82 91
83 Type type; 92 Type type;
84 GURL url; // Empty unless |type == PAC_SOURCE_CUSTOM|. 93 GURL url; // Empty unless |type == PAC_SOURCE_CUSTOM|.
85 }; 94 };
86 95
87 typedef std::vector<PacSource> PacSourceList; 96 typedef std::vector<PacSource> PacSourceList;
88 97
89 enum State { 98 enum State {
90 STATE_NONE, 99 STATE_NONE,
91 STATE_WAIT, 100 STATE_WAIT,
92 STATE_WAIT_COMPLETE, 101 STATE_WAIT_COMPLETE,
93 STATE_FETCH_PAC_SCRIPT, 102 STATE_FETCH_PAC_SCRIPT,
94 STATE_FETCH_PAC_SCRIPT_COMPLETE, 103 STATE_FETCH_PAC_SCRIPT_COMPLETE,
95 STATE_SET_PAC_SCRIPT, 104 STATE_VERIFY_PAC_SCRIPT,
96 STATE_SET_PAC_SCRIPT_COMPLETE, 105 STATE_VERIFY_PAC_SCRIPT_COMPLETE,
97 }; 106 };
98 107
99 // Returns ordered list of PAC urls to try for |config|. 108 // Returns ordered list of PAC urls to try for |config|.
100 PacSourceList BuildPacSourcesFallbackList(const ProxyConfig& config) const; 109 PacSourceList BuildPacSourcesFallbackList(const ProxyConfig& config) const;
101 110
102 void OnIOCompletion(int result); 111 void OnIOCompletion(int result);
103 int DoLoop(int result); 112 int DoLoop(int result);
104 void DoCallback(int result); 113 void DoCallback(int result);
105 114
106 int DoWait(); 115 int DoWait();
107 int DoWaitComplete(int result); 116 int DoWaitComplete(int result);
108 117
109 int DoFetchPacScript(); 118 int DoFetchPacScript();
110 int DoFetchPacScriptComplete(int result); 119 int DoFetchPacScriptComplete(int result);
111 120
112 int DoSetPacScript(); 121 int DoVerifyPacScript();
113 int DoSetPacScriptComplete(int result); 122 int DoVerifyPacScriptComplete(int result);
114 123
115 // Tries restarting using the next fallback PAC URL: 124 // Tries restarting using the next fallback PAC URL:
116 // |pac_sources_[++current_pac_source_index]|. 125 // |pac_sources_[++current_pac_source_index]|.
117 // Returns OK and rewinds the state machine when there 126 // Returns OK and rewinds the state machine when there
118 // is something to try, otherwise returns |error|. 127 // is something to try, otherwise returns |error|.
119 int TryToFallbackPacSource(int error); 128 int TryToFallbackPacSource(int error);
120 129
121 // Gets the initial state (we skip fetching when the 130 // Gets the initial state (we skip fetching when the
122 // ProxyResolver doesn't |expect_pac_bytes()|. 131 // ProxyResolver doesn't |expect_pac_bytes()|.
123 State GetStartState() const; 132 State GetStartState() const;
124 133
125 NetLogStringParameter* CreateNetLogParameterAndDetermineURL( 134 NetLogStringParameter* CreateNetLogParameterAndDetermineURL(
126 const PacSource& pac_source, GURL* effective_pac_url); 135 const PacSource& pac_source, GURL* effective_pac_url);
127 136
128 // Returns the current PAC URL we are fetching/testing. 137 // Returns the current PAC URL we are fetching/testing.
129 const PacSource& current_pac_source() const; 138 const PacSource& current_pac_source() const;
130 139
131 void OnWaitTimerFired(); 140 void OnWaitTimerFired();
132 void DidCompleteInit(); 141 void DidComplete();
133 void Cancel(); 142 void Cancel();
134 143
135 ProxyResolver* resolver_; 144 ProxyResolver* resolver_;
136 ProxyScriptFetcher* proxy_script_fetcher_; 145 ProxyScriptFetcher* proxy_script_fetcher_;
137 DhcpProxyScriptFetcher* dhcp_proxy_script_fetcher_; 146 DhcpProxyScriptFetcher* dhcp_proxy_script_fetcher_;
138 147
139 OldCompletionCallbackImpl<InitProxyResolver> io_callback_; 148 OldCompletionCallbackImpl<ProxyScriptDecider> io_callback_;
140 OldCompletionCallback* user_callback_; 149 OldCompletionCallback* user_callback_;
141 150
142 size_t current_pac_source_index_; 151 size_t current_pac_source_index_;
143 152
144 // Filled when the PAC script fetch completes. 153 // Filled when the PAC script fetch completes.
145 string16 pac_script_; 154 string16 pac_script_;
146 155
147 // Flag indicating whether the caller requested a mandatory pac script 156 // Flag indicating whether the caller requested a mandatory pac script
148 // (i.e. fallback to direct connections are prohibited). 157 // (i.e. fallback to direct connections are prohibited).
149 bool pac_mandatory_; 158 bool pac_mandatory_;
150 159
151 PacSourceList pac_sources_; 160 PacSourceList pac_sources_;
152 State next_state_; 161 State next_state_;
153 162
154 BoundNetLog net_log_; 163 BoundNetLog net_log_;
155 164
165 bool fetch_pac_bytes_;
166
156 base::TimeDelta wait_delay_; 167 base::TimeDelta wait_delay_;
157 base::OneShotTimer<InitProxyResolver> wait_timer_; 168 base::OneShotTimer<ProxyScriptDecider> wait_timer_;
158 169
159 ProxyConfig* effective_config_; 170 // Results.
171 ProxyConfig effective_config_;
172 scoped_refptr<ProxyResolverScriptData> script_data_;
160 173
161 DISALLOW_COPY_AND_ASSIGN(InitProxyResolver); 174
175 DISALLOW_COPY_AND_ASSIGN(ProxyScriptDecider);
162 }; 176 };
163 177
164 } // namespace net 178 } // namespace net
165 179
166 #endif // NET_PROXY_INIT_PROXY_RESOLVER_H_ 180 #endif // NET_PROXY_SCRIPT_DECIDER_H
OLDNEW
« no previous file with comments | « net/proxy/init_proxy_resolver_unittest.cc ('k') | net/proxy/proxy_script_decider.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698