fix: restore --ignore-connections-limit functionality (#21286)

This commit is contained in:
Jeremy Apthorp 2019-11-26 13:27:33 -08:00 committed by Robo
parent 149aaeba94
commit 4149d76890
2 changed files with 31 additions and 1 deletions

View file

@ -6,13 +6,17 @@
#include <utility> #include <utility>
#include "base/command_line.h"
#include "base/strings/string_util.h"
#include "content/public/browser/browser_context.h" #include "content/public/browser/browser_context.h"
#include "extensions/browser/extension_navigation_ui_data.h" #include "extensions/browser/extension_navigation_ui_data.h"
#include "mojo/public/cpp/bindings/binding.h" #include "mojo/public/cpp/bindings/binding.h"
#include "net/base/completion_repeating_callback.h" #include "net/base/completion_repeating_callback.h"
#include "net/base/load_flags.h"
#include "net/http/http_util.h" #include "net/http/http_util.h"
#include "services/network/public/cpp/features.h" #include "services/network/public/cpp/features.h"
#include "shell/browser/net/asar/asar_url_loader.h" #include "shell/browser/net/asar/asar_url_loader.h"
#include "shell/common/options_switches.h"
namespace electron { namespace electron {
@ -689,18 +693,40 @@ ProxyingURLLoaderFactory::ProxyingURLLoaderFactory(
if (header_client_receiver) if (header_client_receiver)
url_loader_header_client_receiver_.Bind(std::move(header_client_receiver)); url_loader_header_client_receiver_.Bind(std::move(header_client_receiver));
ignore_connections_limit_domains_ = base::SplitString(
base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII(
switches::kIgnoreConnectionsLimit),
",", base::TRIM_WHITESPACE, base::SPLIT_WANT_NONEMPTY);
} }
ProxyingURLLoaderFactory::~ProxyingURLLoaderFactory() = default; ProxyingURLLoaderFactory::~ProxyingURLLoaderFactory() = default;
bool ProxyingURLLoaderFactory::ShouldIgnoreConnectionsLimit(
const network::ResourceRequest& request) {
for (const auto& domain : ignore_connections_limit_domains_) {
if (request.url.DomainIs(domain)) {
return true;
}
}
return false;
}
void ProxyingURLLoaderFactory::CreateLoaderAndStart( void ProxyingURLLoaderFactory::CreateLoaderAndStart(
mojo::PendingReceiver<network::mojom::URLLoader> loader, mojo::PendingReceiver<network::mojom::URLLoader> loader,
int32_t routing_id, int32_t routing_id,
int32_t request_id, int32_t request_id,
uint32_t options, uint32_t options,
const network::ResourceRequest& request, const network::ResourceRequest& original_request,
network::mojom::URLLoaderClientPtr client, network::mojom::URLLoaderClientPtr client,
const net::MutableNetworkTrafficAnnotationTag& traffic_annotation) { const net::MutableNetworkTrafficAnnotationTag& traffic_annotation) {
// Take a copy so we can mutate the request.
network::ResourceRequest request = original_request;
if (ShouldIgnoreConnectionsLimit(request)) {
request.load_flags |= net::LOAD_IGNORE_LIMITS;
}
// Check if user has intercepted this scheme. // Check if user has intercepted this scheme.
auto it = intercepted_handlers_.find(request.url.scheme()); auto it = intercepted_handlers_.find(request.url.scheme());
if (it != intercepted_handlers_.end()) { if (it != intercepted_handlers_.end()) {

View file

@ -250,6 +250,8 @@ class ProxyingURLLoaderFactory
void RemoveRequest(int32_t network_service_request_id, uint64_t request_id); void RemoveRequest(int32_t network_service_request_id, uint64_t request_id);
void MaybeDeleteThis(); void MaybeDeleteThis();
bool ShouldIgnoreConnectionsLimit(const network::ResourceRequest& request);
// Passed from api::WebRequest. // Passed from api::WebRequest.
WebRequestAPI* web_request_api_; WebRequestAPI* web_request_api_;
@ -279,6 +281,8 @@ class ProxyingURLLoaderFactory
// internally generated request ID for the same request. // internally generated request ID for the same request.
std::map<int32_t, uint64_t> network_request_id_to_web_request_id_; std::map<int32_t, uint64_t> network_request_id_to_web_request_id_;
std::vector<std::string> ignore_connections_limit_domains_;
DISALLOW_COPY_AND_ASSIGN(ProxyingURLLoaderFactory); DISALLOW_COPY_AND_ASSIGN(ProxyingURLLoaderFactory);
}; };