| OLD | NEW |
| 1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2008 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/chrome_url_request_context.h" | 5 #include "chrome/browser/net/chrome_url_request_context.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/string_util.h" | 8 #include "base/string_util.h" |
| 9 #include "chrome/browser/browser_process.h" | 9 #include "chrome/browser/browser_process.h" |
| 10 #include "chrome/browser/chrome_thread.h" | 10 #include "chrome/browser/chrome_thread.h" |
| 11 #include "chrome/browser/extensions/extension.h" | 11 #include "chrome/browser/extensions/extension.h" |
| 12 #include "chrome/browser/extensions/extensions_service.h" | 12 #include "chrome/browser/extensions/extensions_service.h" |
| 13 #include "chrome/browser/extensions/user_script_master.h" | 13 #include "chrome/browser/extensions/user_script_master.h" |
| 14 #include "chrome/browser/profile.h" | 14 #include "chrome/browser/profile.h" |
| 15 #include "chrome/common/chrome_constants.h" | 15 #include "chrome/common/chrome_constants.h" |
| 16 #include "chrome/common/chrome_switches.h" | 16 #include "chrome/common/chrome_switches.h" |
| 17 #include "chrome/common/notification_service.h" | 17 #include "chrome/common/notification_service.h" |
| 18 #include "chrome/common/pref_names.h" | 18 #include "chrome/common/pref_names.h" |
| 19 #include "net/ftp/ftp_network_layer.h" | 19 #include "net/ftp/ftp_network_layer.h" |
| 20 #include "net/http/http_cache.h" | 20 #include "net/http/http_cache.h" |
| 21 #include "net/http/http_network_layer.h" | 21 #include "net/http/http_network_layer.h" |
| 22 #include "net/http/http_util.h" | 22 #include "net/http/http_util.h" |
| 23 #include "net/proxy/proxy_service.h" | 23 #include "net/proxy/proxy_service.h" |
| 24 #include "webkit/glue/webkit_glue.h" | 24 #include "webkit/glue/webkit_glue.h" |
| 25 | 25 |
| 26 // Sets up proxy info if overrides were specified on the command line. | 26 net::ProxyConfig* CreateProxyConfig(const CommandLine& command_line) { |
| 27 // Otherwise returns NULL (meaning we should use the system defaults). | 27 // Scan for all "enable" type proxy switches. |
| 28 // The caller is responsible for deleting returned pointer. | 28 static const wchar_t* proxy_switches[] = { |
| 29 static net::ProxyInfo* CreateProxyInfo(const CommandLine& command_line) { | 29 switches::kProxyServer, |
| 30 net::ProxyInfo* proxy_info = NULL; | 30 switches::kProxyServerPacUrl, |
| 31 switches::kProxyServerAutoDetect, |
| 32 switches::kProxyServerBypassUrls |
| 33 }; |
| 34 |
| 35 bool found_enable_proxy_switch = false; |
| 36 for (size_t i = 0; i < arraysize(proxy_switches); i++) { |
| 37 if (command_line.HasSwitch(proxy_switches[i])) { |
| 38 found_enable_proxy_switch = true; |
| 39 break; |
| 40 } |
| 41 } |
| 42 |
| 43 if (!found_enable_proxy_switch && |
| 44 !command_line.HasSwitch(switches::kNoProxyServer)) { |
| 45 return NULL; |
| 46 } |
| 47 |
| 48 net::ProxyConfig* proxy_config = new net::ProxyConfig(); |
| 49 if (command_line.HasSwitch(switches::kNoProxyServer)) { |
| 50 // Ignore (and warn about) all the other proxy config switches we get if |
| 51 // the no-proxy-server command line argument is present. |
| 52 if (found_enable_proxy_switch) { |
| 53 LOG(WARNING) << "Additional command line proxy switches found when --" |
| 54 << switches::kNoProxyServer << " was specified."; |
| 55 } |
| 56 return proxy_config; |
| 57 } |
| 31 | 58 |
| 32 if (command_line.HasSwitch(switches::kProxyServer)) { | 59 if (command_line.HasSwitch(switches::kProxyServer)) { |
| 33 proxy_info = new net::ProxyInfo(); | |
| 34 const std::wstring& proxy_server = | 60 const std::wstring& proxy_server = |
| 35 command_line.GetSwitchValue(switches::kProxyServer); | 61 command_line.GetSwitchValue(switches::kProxyServer); |
| 36 proxy_info->UseNamedProxy(WideToASCII(proxy_server)); | 62 proxy_config->proxy_rules.ParseFromString(WideToASCII(proxy_server)); |
| 37 } | 63 } |
| 38 | 64 |
| 39 return proxy_info; | 65 if (command_line.HasSwitch(switches::kProxyServerPacUrl)) { |
| 66 proxy_config->pac_url = |
| 67 GURL(WideToASCII(command_line.GetSwitchValue( |
| 68 switches::kProxyServerPacUrl))); |
| 69 } |
| 70 |
| 71 if (command_line.HasSwitch(switches::kProxyServerAutoDetect)) { |
| 72 proxy_config->auto_detect = true; |
| 73 } |
| 74 |
| 75 if (command_line.HasSwitch(switches::kProxyServerBypassUrls)) { |
| 76 proxy_config->ParseNoProxyList( |
| 77 WideToASCII(command_line.GetSwitchValue( |
| 78 switches::kProxyServerBypassUrls))); |
| 79 } |
| 80 |
| 81 return proxy_config; |
| 40 } | 82 } |
| 41 | 83 |
| 42 // Create a proxy service according to the options on command line. | 84 // Create a proxy service according to the options on command line. |
| 43 static net::ProxyService* CreateProxyService(URLRequestContext* context, | 85 static net::ProxyService* CreateProxyService(URLRequestContext* context, |
| 44 const CommandLine& command_line) { | 86 const CommandLine& command_line) { |
| 45 scoped_ptr<net::ProxyInfo> proxy_info(CreateProxyInfo(command_line)); | 87 scoped_ptr<net::ProxyConfig> proxy_config(CreateProxyConfig(command_line)); |
| 46 | 88 |
| 47 bool use_v8 = !command_line.HasSwitch(switches::kWinHttpProxyResolver); | 89 bool use_v8 = !command_line.HasSwitch(switches::kWinHttpProxyResolver); |
| 48 if (use_v8 && command_line.HasSwitch(switches::kSingleProcess)) { | 90 if (use_v8 && command_line.HasSwitch(switches::kSingleProcess)) { |
| 49 // See the note about V8 multithreading in net/proxy/proxy_resolver_v8.h | 91 // See the note about V8 multithreading in net/proxy/proxy_resolver_v8.h |
| 50 // to understand why we have this limitation. | 92 // to understand why we have this limitation. |
| 51 LOG(ERROR) << "Cannot use V8 Proxy resolver in single process mode."; | 93 LOG(ERROR) << "Cannot use V8 Proxy resolver in single process mode."; |
| 52 use_v8 = false; // Fallback to non-v8 implementation. | 94 use_v8 = false; // Fallback to non-v8 implementation. |
| 53 } | 95 } |
| 54 | 96 |
| 55 return use_v8 ? | 97 return use_v8 ? |
| 56 net::ProxyService::CreateUsingV8Resolver(proxy_info.get(), context) : | 98 net::ProxyService::CreateUsingV8Resolver(proxy_config.get(), context) : |
| 57 net::ProxyService::Create(proxy_info.get()); | 99 net::ProxyService::Create(proxy_config.get()); |
| 58 } | 100 } |
| 59 | 101 |
| 60 // static | 102 // static |
| 61 ChromeURLRequestContext* ChromeURLRequestContext::CreateOriginal( | 103 ChromeURLRequestContext* ChromeURLRequestContext::CreateOriginal( |
| 62 Profile* profile, const FilePath& cookie_store_path, | 104 Profile* profile, const FilePath& cookie_store_path, |
| 63 const FilePath& disk_cache_path) { | 105 const FilePath& disk_cache_path) { |
| 64 DCHECK(!profile->IsOffTheRecord()); | 106 DCHECK(!profile->IsOffTheRecord()); |
| 65 ChromeURLRequestContext* context = new ChromeURLRequestContext(profile); | 107 ChromeURLRequestContext* context = new ChromeURLRequestContext(profile); |
| 66 | 108 |
| 67 context->proxy_service_ = CreateProxyService( | 109 context->proxy_service_ = CreateProxyService( |
| (...skipping 266 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 334 // Do not delete the cookie store in the case of the media context, as it is | 376 // Do not delete the cookie store in the case of the media context, as it is |
| 335 // owned by the original context. | 377 // owned by the original context. |
| 336 if (!is_media_) | 378 if (!is_media_) |
| 337 delete cookie_store_; | 379 delete cookie_store_; |
| 338 | 380 |
| 339 // Do not delete the proxy service in the case of OTR or media contexts, as | 381 // Do not delete the proxy service in the case of OTR or media contexts, as |
| 340 // it is owned by the original URLRequestContext. | 382 // it is owned by the original URLRequestContext. |
| 341 if (!is_off_the_record_ && !is_media_) | 383 if (!is_off_the_record_ && !is_media_) |
| 342 delete proxy_service_; | 384 delete proxy_service_; |
| 343 } | 385 } |
| OLD | NEW |