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 #include "chrome/browser/net/proxy_service_factory.h" | 5 #include "chrome/browser/net/proxy_service_factory.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/string_number_conversions.h" | 8 #include "base/string_number_conversions.h" |
9 #include "chrome/browser/browser_process.h" | 9 #include "chrome/browser/browser_process.h" |
10 #include "chrome/browser/net/pref_proxy_config_service.h" | |
11 #include "chrome/browser/io_thread.h" | 10 #include "chrome/browser/io_thread.h" |
| 11 #include "chrome/browser/net/pref_proxy_config_tracker.h" |
12 #include "chrome/common/chrome_switches.h" | 12 #include "chrome/common/chrome_switches.h" |
13 #include "content/browser/browser_thread.h" | 13 #include "content/browser/browser_thread.h" |
14 #include "net/base/net_log.h" | 14 #include "net/base/net_log.h" |
15 #include "net/proxy/dhcp_proxy_script_fetcher_factory.h" | 15 #include "net/proxy/dhcp_proxy_script_fetcher_factory.h" |
16 #include "net/proxy/proxy_config_service.h" | 16 #include "net/proxy/proxy_config_service.h" |
17 #include "net/proxy/proxy_script_fetcher_impl.h" | 17 #include "net/proxy/proxy_script_fetcher_impl.h" |
18 #include "net/proxy/proxy_service.h" | 18 #include "net/proxy/proxy_service.h" |
19 #include "net/url_request/url_request_context.h" | 19 #include "net/url_request/url_request_context.h" |
20 | 20 |
21 #if defined(OS_CHROMEOS) | 21 #if defined(OS_CHROMEOS) |
22 #include "chrome/browser/chromeos/proxy_config_service.h" | 22 #include "chrome/browser/chromeos/proxy_config_service_impl.h" |
23 #endif // defined(OS_CHROMEOS) | 23 #endif // defined(OS_CHROMEOS) |
24 | 24 |
25 // static | 25 // static |
26 net::ProxyConfigService* ProxyServiceFactory::CreateProxyConfigService( | 26 ChromeProxyConfigService* ProxyServiceFactory::CreateProxyConfigService() { |
27 PrefProxyConfigTracker* proxy_config_tracker) { | |
28 // The linux gconf-based proxy settings getter relies on being initialized | 27 // The linux gconf-based proxy settings getter relies on being initialized |
29 // from the UI thread. | 28 // from the UI thread. |
30 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 29 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
31 | 30 |
32 // Create a baseline service that provides proxy configuration in case nothing | |
33 // is configured through prefs (Note: prefs include command line and | |
34 // configuration policy). | |
35 net::ProxyConfigService* base_service = NULL; | 31 net::ProxyConfigService* base_service = NULL; |
36 | 32 |
| 33 #if !defined(OS_CHROMEOS) |
| 34 // On ChromeOS, base service is NULL; chromeos::ProxyConfigServiceImpl |
| 35 // determines the effective proxy config to take effect in the network layer, |
| 36 // be it from prefs or system (which is network flimflam on chromeos). |
| 37 |
| 38 // For other platforms, create a baseline service that provides proxy |
| 39 // configuration in case nothing is configured through prefs (Note: prefs |
| 40 // include command line and configuration policy). |
| 41 |
37 // TODO(port): the IO and FILE message loops are only used by Linux. Can | 42 // TODO(port): the IO and FILE message loops are only used by Linux. Can |
38 // that code be moved to chrome/browser instead of being in net, so that it | 43 // that code be moved to chrome/browser instead of being in net, so that it |
39 // can use BrowserThread instead of raw MessageLoop pointers? See bug 25354. | 44 // can use BrowserThread instead of raw MessageLoop pointers? See bug 25354. |
40 #if defined(OS_CHROMEOS) | |
41 base_service = new chromeos::ProxyConfigService( | |
42 g_browser_process->chromeos_proxy_config_service_impl()); | |
43 #else | |
44 base_service = net::ProxyService::CreateSystemProxyConfigService( | 45 base_service = net::ProxyService::CreateSystemProxyConfigService( |
45 g_browser_process->io_thread()->message_loop(), | 46 g_browser_process->io_thread()->message_loop(), |
46 g_browser_process->file_thread()->message_loop()); | 47 g_browser_process->file_thread()->message_loop()); |
| 48 #endif // !defined(OS_CHROMEOS) |
| 49 |
| 50 return new ChromeProxyConfigService(base_service); |
| 51 } |
| 52 |
| 53 // static |
| 54 #if defined(OS_CHROMEOS) |
| 55 chromeos::ProxyConfigServiceImpl* |
| 56 ProxyServiceFactory::CreatePrefProxyConfigTracker( |
| 57 PrefService* pref_service) { |
| 58 return new chromeos::ProxyConfigServiceImpl(pref_service); |
| 59 } |
| 60 #else |
| 61 PrefProxyConfigTracker* ProxyServiceFactory::CreatePrefProxyConfigTracker( |
| 62 PrefService* pref_service) { |
| 63 return new PrefProxyConfigTracker(pref_service); |
| 64 } |
47 #endif // defined(OS_CHROMEOS) | 65 #endif // defined(OS_CHROMEOS) |
48 | 66 |
49 return new PrefProxyConfigService(proxy_config_tracker, base_service); | |
50 } | |
51 | |
52 // static | 67 // static |
53 net::ProxyService* ProxyServiceFactory::CreateProxyService( | 68 net::ProxyService* ProxyServiceFactory::CreateProxyService( |
54 net::NetLog* net_log, | 69 net::NetLog* net_log, |
55 net::URLRequestContext* context, | 70 net::URLRequestContext* context, |
56 net::ProxyConfigService* proxy_config_service, | 71 net::ProxyConfigService* proxy_config_service, |
57 const CommandLine& command_line) { | 72 const CommandLine& command_line) { |
58 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 73 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
59 | 74 |
60 bool use_v8 = !command_line.HasSwitch(switches::kWinHttpProxyResolver); | 75 bool use_v8 = !command_line.HasSwitch(switches::kWinHttpProxyResolver); |
61 if (use_v8 && command_line.HasSwitch(switches::kSingleProcess)) { | 76 if (use_v8 && command_line.HasSwitch(switches::kSingleProcess)) { |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
98 context->network_delegate()); | 113 context->network_delegate()); |
99 } else { | 114 } else { |
100 proxy_service = net::ProxyService::CreateUsingSystemProxyResolver( | 115 proxy_service = net::ProxyService::CreateUsingSystemProxyResolver( |
101 proxy_config_service, | 116 proxy_config_service, |
102 num_pac_threads, | 117 num_pac_threads, |
103 net_log); | 118 net_log); |
104 } | 119 } |
105 | 120 |
106 return proxy_service; | 121 return proxy_service; |
107 } | 122 } |
OLD | NEW |