 Chromium Code Reviews
 Chromium Code Reviews Issue 6292017:
  Extended: Add "system" URLRequestContext  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src
    
  
    Issue 6292017:
  Extended: Add "system" URLRequestContext  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src| Index: chrome/browser/net/proxy_service_factory.cc | 
| diff --git a/chrome/browser/net/proxy_service_factory.cc b/chrome/browser/net/proxy_service_factory.cc | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..2b2e28136a055d1ce08206936a7b4704605ca03c | 
| --- /dev/null | 
| +++ b/chrome/browser/net/proxy_service_factory.cc | 
| @@ -0,0 +1,108 @@ | 
| +// Copyright (c) 2011 The Chromium Authors. All rights reserved. | 
| +// Use of this source code is governed by a BSD-style license that can be | 
| +// found in the LICENSE file. | 
| + | 
| +#include "chrome/browser/net/proxy_service_factory.h" | 
| + | 
| +#include "base/command_line.h" | 
| +#include "base/string_number_conversions.h" | 
| +#include "content/browser/browser_thread.h" | 
| +#include "chrome/browser/browser_process.h" | 
| +#include "chrome/browser/net/pref_proxy_config_service.h" | 
| +#include "chrome/browser/io_thread.h" | 
| 
Mattias Nissler (ping if slow)
2011/03/09 11:04:56
needed?
 
battre
2011/03/09 19:24:07
Yes. g_browser_process->io_thread()
 | 
| +#include "chrome/browser/profiles/profile.h" | 
| 
Mattias Nissler (ping if slow)
2011/03/09 11:04:56
needed?
 
battre
2011/03/09 19:24:07
Done.
 | 
| +#include "chrome/common/chrome_switches.h" | 
| +#include "net/base/net_log.h" | 
| +#include "net/proxy/proxy_config_service.h" | 
| +#include "net/proxy/proxy_script_fetcher_impl.h" | 
| +#include "net/url_request/url_request_context.h" | 
| + | 
| +#if defined(OS_CHROMEOS) | 
| +#include "chrome/browser/chromeos/cros/cros_library.h" | 
| +#include "chrome/browser/chromeos/cros/libcros_service_library.h" | 
| +#include "chrome/browser/chromeos/proxy_config_service.h" | 
| +#endif // defined(OS_CHROMEOS) | 
| + | 
| +// static | 
| +net::ProxyConfigService* ProxyServiceFactory::CreateProxyConfigService( | 
| + PrefProxyConfigTracker* proxy_config_tracker) { | 
| + // The linux gconf-based proxy settings getter relies on being initialized | 
| + // from the UI thread. | 
| + DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 
| + | 
| + // Create a baseline service that provides proxy configuration in case nothing | 
| + // is configured through prefs (Note: prefs include command line and | 
| + // configuration policy). | 
| + net::ProxyConfigService* base_service = NULL; | 
| + | 
| + // TODO(port): the IO and FILE message loops are only used by Linux. Can | 
| + // that code be moved to chrome/browser instead of being in net, so that it | 
| + // can use BrowserThread instead of raw MessageLoop pointers? See bug 25354. | 
| +#if defined(OS_CHROMEOS) | 
| + base_service = new chromeos::ProxyConfigService( | 
| + g_browser_process->chromeos_proxy_config_service_impl()); | 
| +#else | 
| + base_service = net::ProxyService::CreateSystemProxyConfigService( | 
| + g_browser_process->io_thread()->message_loop(), | 
| + g_browser_process->file_thread()->message_loop()); | 
| +#endif // defined(OS_CHROMEOS) | 
| + | 
| + return new PrefProxyConfigService(proxy_config_tracker, base_service); | 
| +} | 
| + | 
| +// static | 
| +net::ProxyService* ProxyServiceFactory::CreateProxyService( | 
| + net::NetLog* net_log, | 
| + net::URLRequestContext* context, | 
| + net::ProxyConfigService* proxy_config_service, | 
| + const CommandLine& command_line) { | 
| + DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 
| + | 
| + bool use_v8 = !command_line.HasSwitch(switches::kWinHttpProxyResolver); | 
| + if (use_v8 && command_line.HasSwitch(switches::kSingleProcess)) { | 
| + // See the note about V8 multithreading in net/proxy/proxy_resolver_v8.h | 
| + // to understand why we have this limitation. | 
| + LOG(ERROR) << "Cannot use V8 Proxy resolver in single process mode."; | 
| + use_v8 = false; // Fallback to non-v8 implementation. | 
| + } | 
| + | 
| + size_t num_pac_threads = 0u; // Use default number of threads. | 
| + | 
| + // Check the command line for an override on the number of proxy resolver | 
| + // threads to use. | 
| + if (command_line.HasSwitch(switches::kNumPacThreads)) { | 
| + std::string s = command_line.GetSwitchValueASCII(switches::kNumPacThreads); | 
| + | 
| + // Parse the switch (it should be a positive integer formatted as decimal). | 
| + int n; | 
| + if (base::StringToInt(s, &n) && n > 0) { | 
| + num_pac_threads = static_cast<size_t>(n); | 
| + } else { | 
| + LOG(ERROR) << "Invalid switch for number of PAC threads: " << s; | 
| + } | 
| + } | 
| + | 
| + net::ProxyService* proxy_service; | 
| + if (use_v8) { | 
| + proxy_service = net::ProxyService::CreateUsingV8ProxyResolver( | 
| + proxy_config_service, | 
| + num_pac_threads, | 
| + new net::ProxyScriptFetcherImpl(context), | 
| + context->host_resolver(), | 
| + net_log); | 
| + } else { | 
| + proxy_service = net::ProxyService::CreateUsingSystemProxyResolver( | 
| + proxy_config_service, | 
| + num_pac_threads, | 
| + net_log); | 
| + } | 
| + | 
| +#if defined(OS_CHROMEOS) | 
| + if (chromeos::CrosLibrary::Get()->EnsureLoaded()) { | 
| + chromeos::CrosLibrary::Get()->GetLibCrosServiceLibrary()-> | 
| + RegisterNetworkProxyHandler(proxy_service); | 
| + } | 
| +#endif // defined(OS_CHROMEOS) | 
| + | 
| + return proxy_service; | 
| +} |