diff options
author | eroman@chromium.org <eroman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-05-19 21:01:08 +0000 |
---|---|---|
committer | eroman@chromium.org <eroman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-05-19 21:01:08 +0000 |
commit | 1eae973272945a9d601f8cb2e54d7417a714d41d (patch) | |
tree | 8520d27468021da45e9ba3889769e19e9d626aff | |
parent | 370b967f2d495622ad5a6216d0eb8901d71f5435 (diff) | |
download | chromium_src-1eae973272945a9d601f8cb2e54d7417a714d41d.zip chromium_src-1eae973272945a9d601f8cb2e54d7417a714d41d.tar.gz chromium_src-1eae973272945a9d601f8cb2e54d7417a714d41d.tar.bz2 |
Reorganize the ProxyService::Create() and ProxyService::CreateWithoutV8Resolver() methods.
Instead of using a NULL ProxyResolver dependency in cases where PAC is not supported, it uses a ProxyResolverNull (always fail) implementation.
This is to avoid needing to check in other cases (when v8 is unsupported) if there is a non-null ProxyResolver.
Review URL: http://codereview.chromium.org/115532
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@16413 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | net/proxy/proxy_service.cc | 102 | ||||
-rw-r--r-- | net/proxy/proxy_service.h | 8 |
2 files changed, 62 insertions, 48 deletions
diff --git a/net/proxy/proxy_service.cc b/net/proxy/proxy_service.cc index c2ae532..d172f92 100644 --- a/net/proxy/proxy_service.cc +++ b/net/proxy/proxy_service.cc @@ -32,11 +32,25 @@ namespace net { // Config getter that fails every time. class ProxyConfigServiceNull : public ProxyConfigService { public: + // ProxyConfigService implementation: virtual int GetProxyConfig(ProxyConfig* config) { return ERR_NOT_IMPLEMENTED; } }; +// Proxy resolver that fails every time. +class ProxyResolverNull : public ProxyResolver { + public: + ProxyResolverNull() : ProxyResolver(true /*does_fetch*/) {} + + // ProxyResolver implementation: + virtual int GetProxyForURL(const GURL& /*query_url*/, + const GURL& /*pac_url*/, + ProxyInfo* /*results*/) { + return ERR_NOT_IMPLEMENTED; + } +}; + // Strip away any reference fragments and the username/password, as they // are not relevant to proxy resolution. static GURL SanitizeURLForProxyResolver(const GURL& url) { @@ -194,61 +208,26 @@ ProxyService::ProxyService(ProxyConfigService* config_service, // static ProxyService* ProxyService::Create(const ProxyConfig* pc) { - scoped_ptr<ProxyConfigService> proxy_config_service; - scoped_ptr<ProxyResolver> proxy_resolver; - if (pc) { - proxy_config_service.reset(new ProxyConfigServiceFixed(*pc)); - } - -#if defined(OS_WIN) - if (proxy_config_service == NULL) - proxy_config_service.reset(new ProxyConfigServiceWin()); - proxy_resolver.reset(new ProxyResolverWinHttp()); -#elif defined(OS_MACOSX) - if (proxy_config_service == NULL) - proxy_config_service.reset(new ProxyConfigServiceMac()); - proxy_resolver.reset(new ProxyResolverMac()); -#elif defined(OS_LINUX) - // On Linux we use the V8Resolver, no fallback implementation. - // This means that if we got called with a ProxyConfig that could require a - // resolver, or if the caller is trying to create a regular ProxyService via - // this method instead of CreateUsingV8Resolver() we have to return a - // nulled-out ProxyService. - if (!pc || pc->MayRequirePACResolver()) { - LOG(WARNING) << "Attempting to create a ProxyService with a non-v8 " - << "resolver using an invalid ProxyConfig."; - return CreateNull(); - } -#else - return CreateNull(); -#endif + // Choose the system configuration service appropriate for each platform. + ProxyConfigService* proxy_config_service = pc ? + new ProxyConfigServiceFixed(*pc) : + CreateSystemProxyConfigService(); - return new ProxyService(proxy_config_service.release(), - proxy_resolver.release()); + // Try to choose a non-v8 proxy resolver implementation. + return new ProxyService(proxy_config_service, CreateNonV8ProxyResolver()); } // static ProxyService* ProxyService::CreateUsingV8Resolver( const ProxyConfig* pc, URLRequestContext* url_request_context) { // Choose the system configuration service appropriate for each platform. - ProxyConfigService* config_service = NULL; - if (pc) { - config_service = new ProxyConfigServiceFixed(*pc); - } else { -#if defined(OS_WIN) - config_service = new ProxyConfigServiceWin(); -#elif defined(OS_MACOSX) - config_service = new ProxyConfigServiceMac(); -#elif defined(OS_LINUX) - config_service = new ProxyConfigServiceLinux(); -#else - return CreateNull(); -#endif - } + ProxyConfigService* proxy_config_service = pc ? + new ProxyConfigServiceFixed(*pc) : + CreateSystemProxyConfigService(); // Create a ProxyService that uses V8 to evaluate PAC scripts. ProxyService* proxy_service = new ProxyService( - config_service, new ProxyResolverV8()); + proxy_config_service, new ProxyResolverV8()); // Configure PAC script downloads to be issued using |url_request_context|. proxy_service->SetProxyScriptFetcher( @@ -259,9 +238,8 @@ ProxyService* ProxyService::CreateUsingV8Resolver( // static ProxyService* ProxyService::CreateNull() { - // The ProxyResolver is set to NULL, since it should never be called - // (because the configuration will never require PAC). - return new ProxyService(new ProxyConfigServiceNull, NULL); + // Use a configuration fetcher and proxy resolver which always fail. + return new ProxyService(new ProxyConfigServiceNull, new ProxyResolverNull); } int ProxyService::ResolveProxy(const GURL& url, ProxyInfo* result, @@ -550,6 +528,34 @@ void ProxyService::DidCompletePacRequest(int config_id, int result_code) { config_is_bad_ = true; } +// static +ProxyConfigService* ProxyService::CreateSystemProxyConfigService() { +#if defined(OS_WIN) + return new ProxyConfigServiceWin(); +#elif defined(OS_MACOSX) + return new ProxyConfigServiceMac(); +#elif defined(OS_LINUX) + return new ProxyConfigServiceLinux(); +#else + LOG(WARNING) << "Failed to choose a system proxy settings fetcher " + "for this platform."; + return new ProxyConfigServiceNull(); +#endif +} + +// static +ProxyResolver* ProxyService::CreateNonV8ProxyResolver() { +#if defined(OS_WIN) + return new ProxyResolverWinHttp(); +#elif defined(OS_MACOSX) + return new ProxyResolverMac(); +#else + LOG(WARNING) << "PAC support disabled because there is no fallback " + "non-V8 implementation"; + return new ProxyResolverNull(); +#endif +} + void ProxyService::UpdateConfig() { bool is_first_update = !config_has_been_initialized(); diff --git a/net/proxy/proxy_service.h b/net/proxy/proxy_service.h index f2fbbe7..4227586 100644 --- a/net/proxy/proxy_service.h +++ b/net/proxy/proxy_service.h @@ -112,6 +112,14 @@ class ProxyService { private: friend class PacRequest; + // Creates a config service appropriate for this platform that fetches the + // system proxy settings. + static ProxyConfigService* CreateSystemProxyConfigService(); + + // Creates a proxy resolver appropriate for this platform that doesn't rely + // on V8. + static ProxyResolver* CreateNonV8ProxyResolver(); + ProxyResolver* resolver() { return resolver_.get(); } base::Thread* pac_thread() { return pac_thread_.get(); } |