mirror of
https://github.com/electron/electron.git
synced 2026-04-10 03:01:51 -04:00
* chore: bump chromium in DEPS to 98.0.4732.0 * chore: bump chromium in DEPS to 98.0.4734.0 * chore: bump chromium in DEPS to 98.0.4736.0 * chore: bump chromium in DEPS to 98.0.4738.0 * chore: bump chromium in DEPS to 98.0.4740.0 * chore: bump chromium in DEPS to 98.0.4742.0 * chore: bump chromium in DEPS to 98.0.4744.0 * chore: bump chromium in DEPS to 98.0.4746.0 * chore: bump chromium in DEPS to 98.0.4748.0 * chore: bump chromium in DEPS to 98.0.4750.0 * chore: bump chromium in DEPS to 98.0.4752.0 * chore: bump chromium in DEPS to 98.0.4754.0 * chore: bump chromium in DEPS to 98.0.4756.0 * chore: bump chromium in DEPS to 98.0.4758.0 * chore: bump chromium in DEPS to 98.0.4758.3 * chore: bump chromium in DEPS to 98.0.4758.5 * chore: bump chromium in DEPS to 98.0.4758.9 * chore: bump chromium in DEPS to 98.0.4758.10 * chore: bump chromium in DEPS to 98.0.4758.9 * chore: bump chromium in DEPS to 98.0.4758.10 * chore: bump chromium in DEPS to 98.0.4758.9 * chore: bump chromium in DEPS to 98.0.4758.10 * chore: bump chromium in DEPS to 98.0.4758.9 * chore: bump chromium in DEPS to 98.0.4758.10 * chore: bump chromium in DEPS to 98.0.4758.9 * chore: bump chromium in DEPS to 98.0.4758.10 * 3292117: Remove unneeded base/compiler_specific.h includes in //chrome. https://chromium-review.googlesource.com/c/chromium/src/+/3292117 (cherry picked from commit 1a84b21a5e461927c13a0601395b036cf668077a) * 3289198: Enables calculating line, word and sentence boundaries on the browser https://chromium-review.googlesource.com/c/chromium/src/+/3289198 (cherry picked from commit c8b1766a789d596273fe6bee8adab62e7963bc17) * 3276176: Remove expired gdi-text-printing flag and associated code. https://chromium-review.googlesource.com/c/chromium/src/+/3276176 (cherry picked from commit 0abd3208d6aa42f9329d50407290536d3196a19b) * 3240963: content: allow embedder to prevent locking scheme registry https://chromium-review.googlesource.com/c/chromium/src/+/3240963 (cherry picked from commit 19540a965d47205cb079738d3d11b12f82edbb98) * 3269899: Rename WebContentsImpl::GetFrameTree to GetPrimaryFrameTree https://chromium-review.googlesource.com/c/chromium/src/+/3269899 (cherry picked from commit a5b704e184c45cffd2dbc97e42bec76d52ed3f7a) * chore: fixup patch indices (cherry picked from commit dd9cb2a448c7368abab9e6733e442ad75ca9fc38) * 3276279: Enable -Wshadow by default for the "chromium code" config. https://chromium-review.googlesource.com/c/chromium/src/+/3276279 (cherry picked from commit ec20f7fc862de2b0057fe4d59c13d94b70a9e13c) * 3279737: appcache: Remove WebPreference/WebSetting https://chromium-review.googlesource.com/c/chromium/src/+/3279737 (cherry picked from commit 04088b5a4413f074cd4090838ed4ccb123f32c56) * 3275564: [api] Advance API deprecation for APIs last marked in v9.6 https://chromium-review.googlesource.com/c/v8/v8/+/3275564 (cherry picked from commit 72ef5a0bced84ca5dbacb0de4e63fe73fc8d34e5) * 3261873: Clean up WebScriptSource constructors https://chromium-review.googlesource.com/c/chromium/src/+/3261873 (cherry picked from commit c277b0b411b2dcfabdab2798dd489aab2a01fa2c) * 3279346: appcache: Remove ConsoleMessage appcache field https://chromium-review.googlesource.com/c/chromium/src/+/3279346 (cherry picked from commit ea85e829ccd6fbf019b0056300232d0a4bf6a8e8) * 3264212: Move legacy file loading to legacy_test_runner https://chromium-review.googlesource.com/c/devtools/devtools-frontend/+/3264212 Both Persistence and UI have been removed from globals, but the issues they seemed to be patching are no longer reproducible from what I can tell, and so we can just delete these and re-evaluate if something surfaces. (cherry picked from commit f3e01465ce8b15af93aebdb5bd08fffed9dbe81c) * 3290415: x11: remove the USE_X11 define. https://chromium-review.googlesource.com/c/chromium/src/+/3290415 (cherry picked from commit 1351e45cb53851018675e707941d71f44e7bb2a7) * 3179530: Defer system calls in PrintingContext for OOP printing https://chromium-review.googlesource.com/c/chromium/src/+/3179530 (cherry picked from commit 4e235ab720ec3f2f7112b47be948469e9fc9023a) * 3299445: Consolidate is_win conditionals in chrome/test/BUILD.gn. https://chromium-review.googlesource.com/c/chromium/src/+/3299445 (cherry picked from commit d09ef41fc11f8190d6174d48506291c462420bbc) * chore: update patch indices (cherry picked from commit 77b72f77b8322e75c72debe446c34e38ccb0468c) * 3223975: Break PrintJobWorker OOP logic into separate class https://chromium-review.googlesource.com/c/chromium/src/+/3223975 (cherry picked from commit e02a7b1e8025709101f13e8a82398714a3c6f451) * 3279001: Remove support for font-family: -webkit-pictograph https://chromium-review.googlesource.com/c/chromium/src/+/3279001 (cherry picked from commit 01ba427a032dad1a1cb272bca8a420ec4f3d2198) * chore: fixup patch indices (cherry picked from commit 49d33970d6f8c5b5c9393d509c5727e66f9698a1) * chore: update patches (cherry picked from commit 266bb0db2ede34b8569d94fe6725b567a389fa83) * chore: update patches (cherry picked from commit 7ec7dac00dca5f00a09d11fe6b741470e4524519) * chore: update printing patch for miracle ptr (cherry picked from commit 4954c64859a7d4da2e57318b66d09fdc49d11327) * chore: add noexcept to fix clang error (cherry picked from commit ef9b7d1826c20f5df5442962a82815732dfb0086) * chore: update patches (cherry picked from commit 495e5c8dfb203002300f96924199e6cb86fe272e) * chore: update patches (cherry picked from commit c41579b260ae71bef2f6437ff21644ec0858ec35) * 3293841: Remove File Handling permissions code Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3293841 (cherry picked from commit e6a5c4fa0c3d3c4f4cf77961d2f73f6f2bffa4dd) * chore: update patches 3311700: Move the PpapiPluginSandboxedProcessLauncherDelegate | https://chromium-review.googlesource.com/c/chromium/src/+/3311700 (cherry picked from commit 1f0b5231ea12840cc3610ac306ec421d8bc884b1) * 3289260: [CodeHealth]: Remove uses of Notification Service Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3289260 (cherry picked from commit 741d48c9d8e8740c9f3e3c2dbf2072fc76ca92ad) * 3301600: Disable scripted print in fenced frames Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3301600 (cherry picked from commit 9ebe29ae559df0de103b29615990ff7b171e54ca) * chore: add missing thread_restrictions headers (cherry picked from commit 8440c2ff2ec1cb808e8f5d77eb75e41d9be7d0f6) * 3305132: Rewrite most `Foo* field_` pointer fields to `raw_ptr<Foo> field_`. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3305132 (cherry picked from commit f4e090c9190fe919123b660d2e0909f09a66d03b) * fix: add ppapi_sandbox header for linux 3311700: Move the PpapiPluginSandboxedProcessLauncherDelegate | https://chromium-review.googlesource.com/c/chromium/src/+/3311700 (cherry picked from commit 00335143af0dab4a1240670d73f9061f3f7dddb3) * 3321044: Remove DictionaryValue::Clear() Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3321044 (cherry picked from commit 2cba28ab91d6a1e60024d8826e82bbe07e4a1b6e) * chore: update printing.patch Refs: - 3304556: [code health] Remove notification observation from PrintJob. | https://chromium-review.googlesource.com/c/chromium/src/+/3304556 - 3305095: [code health] Remove NotificationService from PrintViewManagerBase. | https://chromium-review.googlesource.com/c/chromium/src/+/3305095 (cherry picked from commit b3e6811a687e5883a2e74ae044a2e52f0ac000bc) * build: add v8-embedder-state headers to GN patch (cherry picked from commit 46b085f0ae7b2fe3556efbed2a36853a23cccc1c) * chore: update patches * chore: update video consumers (cherry picked from commit e78c76f76a3bc2d868a330434e33a16be48ebc76) * refactor: use newer base::Value API (cherry picked from commit 7d711f6a85245bc8b80e7601c992647be2dce40f) * oops 😵💫 (cherry picked from commit e348ab73242e96f5c4d572d00185a5c25c218d26) * chore: rename CookiePartitionKeychain ...to CookiePartitionKeyCollection (cherry picked from commit b88f03dcb225f219ec78dd7463058231c74603e2) * chore: update patch after rebase * fix: WCO method got renamed (cherry picked from commit f80c70fdccbc4847e08b2ef08849a1d00350d341) * build: turn PartitionAlloc back off on mac for now (cherry picked from commit 0ef90f5385411c7f8f9ab3904c644a0f254343cf) * 3344749: Revert "Stop using NSRunLoop in renderer process" https://chromium-review.googlesource.com/c/chromium/src/+/3344749 (cherry picked from commit de8e4afb6f7f24db2a6062dd7d2ddcabf13f3f16) * chore: disable serial device enumerator sequence dcheck (cherry picked from commit c3a51158ed572cecbe5818b78e9c91cd8c7e3367) * chore: bump chromium in DEPS to 98.0.4758.9 * fix: comment out line in DeviceService dtor (cherry picked from commit bf2af594c7336ff0c93a1155de7710a6c7387147) * Revert "chore: bump chromium in DEPS to 98.0.4758.9" This reverts commit 5d2232ff9aa70fb227c984272e2317f3946b03c2. * fix: destructor for EmbedderStateScope * fixup! 3279001: Remove support for font-family: -webkit-pictograph (cherry picked from commit a0707af4facb31b8458723f9647201776b8431a3) * fixup! 3279346: appcache: Remove ConsoleMessage appcache field (cherry picked from commit c947cf23218818b81107c18331eaf21379f11db9) * chore: update patches * chore: bump chromium in DEPS to 98.0.4758.9 * chore: bump chromium in DEPS to 98.0.4758.10 * chore: bump chromium in DEPS to 98.0.4758.9 Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: Samuel Attard <samuel.r.attard@gmail.com> Co-authored-by: VerteDinde <khammond@slack-corp.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: clavin <clavin@electronjs.org> Co-authored-by: John Kleinschmidt <jkleinsc@github.com>
159 lines
8.3 KiB
Diff
159 lines
8.3 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: deepak1556 <hop2deep@gmail.com>
|
|
Date: Tue, 17 Aug 2021 22:42:42 -0700
|
|
Subject: feat: expose raw response headers from URLLoader
|
|
|
|
With https://chromium-review.googlesource.com/c/chromium/src/+/2856099
|
|
unfiltered response headers are only available via trusted channel
|
|
through //services/network/public/mojom/devtools_observer.mojom.
|
|
https://github.com/electron/electron/pull/30503/commits/28f4da1582d046e96cb58f3cbb590503e89dfd0d
|
|
was an attempt to use this interface but given the original response is
|
|
signalled on a different interface via URLLoaderClient::OnReceiveResponse
|
|
it is harder to sync these data from two different channels for a synchronous
|
|
event emitted on the SimpleURLLoaderWrapper::OnResponseStarted.
|
|
|
|
This patch does the minimal approach to add back the raw response
|
|
headers, moving forward we should find a way in upstream to provide
|
|
access to these headers for loader clients created on the browser process.
|
|
|
|
diff --git a/services/network/public/cpp/resource_request.cc b/services/network/public/cpp/resource_request.cc
|
|
index f14c99863eb3f31ebc9ffd30a55f7536585fb561..d1f11d2d13445c9814d2e7227e5e02001377329b 100644
|
|
--- a/services/network/public/cpp/resource_request.cc
|
|
+++ b/services/network/public/cpp/resource_request.cc
|
|
@@ -234,6 +234,7 @@ bool ResourceRequest::EqualsForTesting(const ResourceRequest& request) const {
|
|
do_not_prompt_for_login == request.do_not_prompt_for_login &&
|
|
is_main_frame == request.is_main_frame &&
|
|
transition_type == request.transition_type &&
|
|
+ report_raw_headers == request.report_raw_headers &&
|
|
previews_state == request.previews_state &&
|
|
upgrade_if_insecure == request.upgrade_if_insecure &&
|
|
is_revalidating == request.is_revalidating &&
|
|
diff --git a/services/network/public/cpp/resource_request.h b/services/network/public/cpp/resource_request.h
|
|
index 7c835d244420afe1c9ab6eac267c8789fb2afb01..564caebc55e1338e7124731d639cd6f01aebf595 100644
|
|
--- a/services/network/public/cpp/resource_request.h
|
|
+++ b/services/network/public/cpp/resource_request.h
|
|
@@ -157,6 +157,7 @@ struct COMPONENT_EXPORT(NETWORK_CPP_BASE) ResourceRequest {
|
|
bool do_not_prompt_for_login = false;
|
|
bool is_main_frame = false;
|
|
int transition_type = 0;
|
|
+ bool report_raw_headers = false;
|
|
int previews_state = 0;
|
|
bool upgrade_if_insecure = false;
|
|
bool is_revalidating = false;
|
|
diff --git a/services/network/public/cpp/url_request_mojom_traits.cc b/services/network/public/cpp/url_request_mojom_traits.cc
|
|
index 9fefb0ca05e8f461d22b7f9875cc722232ccaed4..9c020bd1272ad2894f0b5af4c504d551b9927af0 100644
|
|
--- a/services/network/public/cpp/url_request_mojom_traits.cc
|
|
+++ b/services/network/public/cpp/url_request_mojom_traits.cc
|
|
@@ -210,6 +210,7 @@ bool StructTraits<
|
|
out->do_not_prompt_for_login = data.do_not_prompt_for_login();
|
|
out->is_main_frame = data.is_main_frame();
|
|
out->transition_type = data.transition_type();
|
|
+ out->report_raw_headers = data.report_raw_headers();
|
|
out->previews_state = data.previews_state();
|
|
out->upgrade_if_insecure = data.upgrade_if_insecure();
|
|
out->is_revalidating = data.is_revalidating();
|
|
diff --git a/services/network/public/cpp/url_request_mojom_traits.h b/services/network/public/cpp/url_request_mojom_traits.h
|
|
index 53b1cd261ec419dd68906186a3da651fe792ede0..5945e6d9749ad2a888edfa0c4b00377a7190881b 100644
|
|
--- a/services/network/public/cpp/url_request_mojom_traits.h
|
|
+++ b/services/network/public/cpp/url_request_mojom_traits.h
|
|
@@ -272,6 +272,9 @@ struct COMPONENT_EXPORT(NETWORK_CPP_BASE)
|
|
static int32_t transition_type(const network::ResourceRequest& request) {
|
|
return request.transition_type;
|
|
}
|
|
+ static bool report_raw_headers(const network::ResourceRequest& request) {
|
|
+ return request.report_raw_headers;
|
|
+ }
|
|
static int32_t previews_state(const network::ResourceRequest& request) {
|
|
return request.previews_state;
|
|
}
|
|
diff --git a/services/network/public/mojom/url_request.mojom b/services/network/public/mojom/url_request.mojom
|
|
index 27477d595fd22dc49329631a0b52ebdaafe1edb1..a4fd22381738648040cd72dce747285f5fcb698a 100644
|
|
--- a/services/network/public/mojom/url_request.mojom
|
|
+++ b/services/network/public/mojom/url_request.mojom
|
|
@@ -318,6 +318,9 @@ struct URLRequest {
|
|
// about this.
|
|
int32 transition_type;
|
|
|
|
+ // Whether to provide unfiltered response headers.
|
|
+ bool report_raw_headers;
|
|
+
|
|
// Whether or not to request a Preview version of the resource or let the
|
|
// browser decide.
|
|
// Note: this is an enum of type PreviewsState.
|
|
diff --git a/services/network/public/mojom/url_response_head.mojom b/services/network/public/mojom/url_response_head.mojom
|
|
index 76a0a192fda9578fd243063ebad5831762539cf6..47234af6519479ea77d503bacda1a84bf2303acf 100644
|
|
--- a/services/network/public/mojom/url_response_head.mojom
|
|
+++ b/services/network/public/mojom/url_response_head.mojom
|
|
@@ -7,6 +7,7 @@ module network.mojom;
|
|
import "mojo/public/mojom/base/time.mojom";
|
|
import "mojo/public/mojom/base/unguessable_token.mojom";
|
|
import "services/network/public/mojom/fetch_api.mojom";
|
|
+import "services/network/public/mojom/http_raw_headers.mojom";
|
|
import "services/network/public/mojom/ip_endpoint.mojom";
|
|
import "services/network/public/mojom/load_timing_info.mojom";
|
|
import "services/network/public/mojom/network_param.mojom";
|
|
@@ -28,6 +29,9 @@ struct URLResponseHead {
|
|
// The response headers or NULL if the URL type does not support headers.
|
|
HttpResponseHeaders headers;
|
|
|
|
+ // Actual response headers, as obtained from the network stack.
|
|
+ array<HttpRawHeaderPair> raw_response_headers;
|
|
+
|
|
// The mime type of the response. This may be a derived value.
|
|
string mime_type;
|
|
|
|
diff --git a/services/network/url_loader.cc b/services/network/url_loader.cc
|
|
index e53ff47c6f43d00fd89695c4ef08ef5f455df103..56dce34839df7569361bfe7076f6dd2f7ef307c7 100644
|
|
--- a/services/network/url_loader.cc
|
|
+++ b/services/network/url_loader.cc
|
|
@@ -532,6 +532,7 @@ URLLoader::URLLoader(
|
|
peer_closed_handle_watcher_(FROM_HERE,
|
|
mojo::SimpleWatcher::ArmingPolicy::MANUAL,
|
|
base::SequencedTaskRunnerHandle::Get()),
|
|
+ report_raw_headers_(request.report_raw_headers),
|
|
devtools_request_id_(request.devtools_request_id),
|
|
request_mode_(request.mode),
|
|
request_credentials_mode_(request.credentials_mode),
|
|
@@ -690,7 +691,7 @@ URLLoader::URLLoader(
|
|
url_request_->SetRequestHeadersCallback(base::BindRepeating(
|
|
&URLLoader::SetRawRequestHeadersAndNotify, base::Unretained(this)));
|
|
|
|
- if (devtools_request_id()) {
|
|
+ if (devtools_request_id() || report_raw_headers_) {
|
|
url_request_->SetResponseHeadersCallback(base::BindRepeating(
|
|
&URLLoader::SetRawResponseHeaders, base::Unretained(this)));
|
|
}
|
|
@@ -1340,6 +1341,19 @@ void URLLoader::OnResponseStarted(net::URLRequest* url_request, int net_error) {
|
|
response_ = network::mojom::URLResponseHead::New();
|
|
PopulateResourceResponse(url_request_.get(), is_load_timing_enabled_,
|
|
options_, response_.get());
|
|
+ if (raw_response_headers_ && report_raw_headers_) {
|
|
+ std::vector<network::mojom::HttpRawHeaderPairPtr> header_array;
|
|
+ size_t iterator = 0;
|
|
+ std::string name, value;
|
|
+ while (raw_response_headers_->EnumerateHeaderLines(&iterator, &name, &value)) {
|
|
+ network::mojom::HttpRawHeaderPairPtr pair =
|
|
+ network::mojom::HttpRawHeaderPair::New();
|
|
+ pair->key = name;
|
|
+ pair->value = value;
|
|
+ header_array.push_back(std::move(pair));
|
|
+ }
|
|
+ response_->raw_response_headers = std::move(header_array);
|
|
+ }
|
|
DispatchOnRawResponse();
|
|
|
|
// Parse and remove the Trust Tokens response headers, if any are expected,
|
|
diff --git a/services/network/url_loader.h b/services/network/url_loader.h
|
|
index fcc47a2389c5172e3c674e413baa857183e0f2f8..af952b03ca87c4022400ba93d2e1fb8d3759960a 100644
|
|
--- a/services/network/url_loader.h
|
|
+++ b/services/network/url_loader.h
|
|
@@ -503,6 +503,8 @@ class COMPONENT_EXPORT(NETWORK_SERVICE) URLLoader
|
|
std::unique_ptr<ResourceScheduler::ScheduledResourceRequest>
|
|
resource_scheduler_request_handle_;
|
|
|
|
+ // Whether client requested raw headers.
|
|
+ bool report_raw_headers_ = false;
|
|
bool enable_reporting_raw_headers_ = false;
|
|
bool seen_raw_request_headers_ = false;
|
|
scoped_refptr<const net::HttpResponseHeaders> raw_response_headers_;
|