fix: restore --ignore-connections-limit functionality (#21286)
This commit is contained in:
parent
149aaeba94
commit
4149d76890
2 changed files with 31 additions and 1 deletions
|
@ -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()) {
|
||||||
|
|
|
@ -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);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue