From 6df9c04270231f3132fe8165150632f0cdf156ed Mon Sep 17 00:00:00 2001 From: Jeremy Apthorp Date: Thu, 4 Oct 2018 16:22:54 -0700 Subject: [PATCH] Hook up HttpAuthHandlerFactory configuration to the network service https://chromium-review.googlesource.com/c/chromium/src/+/1089661 --- .../browser/net/url_request_context_getter.cc | 76 +++++++++---------- atom/browser/net/url_request_context_getter.h | 6 -- 2 files changed, 36 insertions(+), 46 deletions(-) diff --git a/atom/browser/net/url_request_context_getter.cc b/atom/browser/net/url_request_context_getter.cc index 328b9625bbd2..6e84e2644e15 100644 --- a/atom/browser/net/url_request_context_getter.cc +++ b/atom/browser/net/url_request_context_getter.cc @@ -83,7 +83,6 @@ network::mojom::NetworkContextParamsPtr CreateDefaultNetworkContextParams( network_context_params->accept_language = net::HttpUtil::GenerateAcceptLanguageHeader( brightray::BrowserClient::Get()->GetApplicationLocale()); - network_context_params->allow_gssapi_library_load = true; network_context_params->enable_data_url_support = false; network_context_params->proxy_resolver_factory = ChromeMojoProxyResolverFactory::CreateWithStrongBinding().PassInterface(); @@ -107,6 +106,29 @@ network::mojom::NetworkContextParamsPtr CreateDefaultNetworkContextParams( return network_context_params; } +network::mojom::HttpAuthStaticParamsPtr CreateHttpAuthStaticParams() { + network::mojom::HttpAuthStaticParamsPtr auth_static_params = + network::mojom::HttpAuthStaticParams::New(); + + auth_static_params->supported_schemes = {"basic", "digest", "ntlm", + "negotiate"}; + + return auth_static_params; +} + +network::mojom::HttpAuthDynamicParamsPtr CreateHttpAuthDynamicParams( + const base::CommandLine& command_line) { + network::mojom::HttpAuthDynamicParamsPtr auth_dynamic_params = + network::mojom::HttpAuthDynamicParams::New(); + + auth_dynamic_params->server_whitelist = + command_line.GetSwitchValueASCII(switches::kAuthServerWhitelist); + auth_dynamic_params->delegate_whitelist = command_line.GetSwitchValueASCII( + switches::kAuthNegotiateDelegateWhitelist); + + return auth_dynamic_params; +} + void SetupAtomURLRequestJobFactory( content::ProtocolHandlerMap* protocol_handlers, net::URLRequestContext* url_request_context, @@ -226,8 +248,7 @@ URLRequestContextGetter::Handle::CreateMainRequestContextGetter( DCHECK(!main_request_context_getter_.get()); LazyInitialize(); main_request_context_getter_ = new URLRequestContextGetter( - AtomBrowserClient::Get()->GetNetLog(), this, protocol_handlers, - std::move(protocol_interceptors)); + this, protocol_handlers, std::move(protocol_interceptors)); return main_request_context_getter_; } @@ -284,12 +305,10 @@ void URLRequestContextGetter::Handle::ShutdownOnUIThread() { } URLRequestContextGetter::URLRequestContextGetter( - net::NetLog* net_log, URLRequestContextGetter::Handle* context_handle, content::ProtocolHandlerMap* protocol_handlers, content::URLRequestInterceptorScopedVector protocol_interceptors) - : net_log_(net_log), - context_handle_(context_handle), + : context_handle_(context_handle), url_request_context_(nullptr), protocol_interceptors_(std::move(protocol_interceptors)), context_shutting_down_(false) { @@ -323,6 +342,13 @@ net::URLRequestContext* URLRequestContextGetter::GetURLRequestContext() { if (!url_request_context_) { auto& command_line = *base::CommandLine::ForCurrentProcess(); + // Create the network service, so that shared host resolver + // gets created which is required to set the auth preferences below. + auto* network_service = content::GetNetworkServiceImpl(); + network_service->SetUpHttpAuth(CreateHttpAuthStaticParams()); + network_service->ConfigureHttpAuthPrefs( + CreateHttpAuthDynamicParams(command_line)); + std::unique_ptr builder = std::make_unique(); builder->set_network_delegate(std::make_unique()); @@ -334,42 +360,12 @@ net::URLRequestContext* URLRequestContextGetter::GetURLRequestContext() { builder->SetCreateHttpTransactionFactoryCallback( base::BindOnce(&content::CreateDevToolsNetworkTransactionFactory)); - std::unique_ptr host_resolver = - net::HostResolver::CreateDefaultResolver(net_log_); - // --host-resolver-rules - if (command_line.HasSwitch(network::switches::kHostResolverRules)) { - auto remapped_resolver = - std::make_unique(std::move(host_resolver)); - remapped_resolver->SetRulesFromString(command_line.GetSwitchValueASCII( - network::switches::kHostResolverRules)); - host_resolver = std::move(remapped_resolver); - } - - net::HttpAuthPreferences auth_preferences; - // --auth-server-whitelist - if (command_line.HasSwitch(switches::kAuthServerWhitelist)) { - auth_preferences.SetServerWhitelist( - command_line.GetSwitchValueASCII(switches::kAuthServerWhitelist)); - } - - // --auth-negotiate-delegate-whitelist - if (command_line.HasSwitch(switches::kAuthNegotiateDelegateWhitelist)) { - auth_preferences.SetDelegateWhitelist(command_line.GetSwitchValueASCII( - switches::kAuthNegotiateDelegateWhitelist)); - } - auto http_auth_handler_factory = - net::HttpAuthHandlerRegistryFactory::CreateDefault(host_resolver.get()); - http_auth_handler_factory->SetHttpAuthPreferences(net::kNegotiateAuthScheme, - &auth_preferences); - builder->SetHttpAuthHandlerFactory(std::move(http_auth_handler_factory)); - builder->set_host_resolver(std::move(host_resolver)); builder->set_ct_verifier(std::make_unique()); - network_context_ = - content::GetNetworkServiceImpl()->CreateNetworkContextWithBuilder( - std::move(context_handle_->main_network_context_request_), - std::move(context_handle_->main_network_context_params_), - std::move(builder), &url_request_context_); + network_context_ = network_service->CreateNetworkContextWithBuilder( + std::move(context_handle_->main_network_context_request_), + std::move(context_handle_->main_network_context_params_), + std::move(builder), &url_request_context_); net::TransportSecurityState* transport_security_state = url_request_context_->transport_security_state(); diff --git a/atom/browser/net/url_request_context_getter.h b/atom/browser/net/url_request_context_getter.h index dd8798eeebfa..861f33bc60a3 100644 --- a/atom/browser/net/url_request_context_getter.h +++ b/atom/browser/net/url_request_context_getter.h @@ -23,10 +23,6 @@ namespace brightray { class RequireCTDelegate; } // namespace brightray -namespace net { -class NetLog; -} - namespace atom { class AtomBrowserContext; @@ -88,7 +84,6 @@ class URLRequestContextGetter : public net::URLRequestContextGetter { }; URLRequestContextGetter( - net::NetLog* net_log, URLRequestContextGetter::Handle* context_handle, content::ProtocolHandlerMap* protocol_handlers, content::URLRequestInterceptorScopedVector protocol_interceptors); @@ -102,7 +97,6 @@ class URLRequestContextGetter : public net::URLRequestContextGetter { std::unique_ptr top_job_factory_; std::unique_ptr network_context_; - net::NetLog* net_log_; URLRequestContextGetter::Handle* context_handle_; net::URLRequestContext* url_request_context_; content::ProtocolHandlerMap protocol_handlers_;