diff options
author | horo <horo@chromium.org> | 2014-10-31 19:08:28 -0700 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2014-11-01 02:08:43 +0000 |
commit | e09b6c8616f4a8e45e91a171eedddefde9522ac2 (patch) | |
tree | a2bf42602693c66c8d5089e68aca52f7ae788d9a /chrome/browser/renderer_host/chrome_resource_dispatcher_host_delegate.cc | |
parent | 2178ec8cf854f0996a2d66649f52841e1ed18795 (diff) | |
download | chromium_src-e09b6c8616f4a8e45e91a171eedddefde9522ac2.zip chromium_src-e09b6c8616f4a8e45e91a171eedddefde9522ac2.tar.gz chromium_src-e09b6c8616f4a8e45e91a171eedddefde9522ac2.tar.bz2 |
[ServiceWorker] Don't send the UMA related headers to the ServiceWorker.
Chrome add "X-Chrome-UMA-Enabled" (and sometimes "X-Client-Data") headers while accessing Google servers if UMA is enabled.
This header is added before sending the request to the ServiceWorker.
So the request which is passed to the ServiceWorker contains this header.
If event.request.mode is 'cors' and event.request.headers has "x-chrome-uma-enabled", fetch(event.request) send a CORS preflight request.
This preflight request contains "Access-Control-Request-Headers: x-chrome-uma-enabled" header.
But the response from the Google server doesn't contain "Access-Control-Allow-Headers: x-chrome-uma-enabled" header.
So this fetch fails.
To avoid this problem this patch removes these headers before sending the request to the ServiceWorker.
This patch introduces ServiceWorkerContext::AddExcludedHeadersForFetchEvent() method and changes DevToolsNetworkTransactionFactory to call this method.
BUG=425649
Review URL: https://codereview.chromium.org/666973003
Cr-Commit-Position: refs/heads/master@{#302379}
Diffstat (limited to 'chrome/browser/renderer_host/chrome_resource_dispatcher_host_delegate.cc')
-rw-r--r-- | chrome/browser/renderer_host/chrome_resource_dispatcher_host_delegate.cc | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/chrome/browser/renderer_host/chrome_resource_dispatcher_host_delegate.cc b/chrome/browser/renderer_host/chrome_resource_dispatcher_host_delegate.cc index fd8b196..6188b5e 100644 --- a/chrome/browser/renderer_host/chrome_resource_dispatcher_host_delegate.cc +++ b/chrome/browser/renderer_host/chrome_resource_dispatcher_host_delegate.cc @@ -42,6 +42,7 @@ #include "content/public/browser/resource_context.h" #include "content/public/browser/resource_dispatcher_host.h" #include "content/public/browser/resource_request_info.h" +#include "content/public/browser/service_worker_context.h" #include "content/public/browser/stream_info.h" #include "content/public/browser/web_contents.h" #include "content/public/common/resource_response.h" @@ -271,6 +272,12 @@ ChromeResourceDispatcherHostDelegate::ChromeResourceDispatcherHostDelegate( user_script_listener_(new extensions::UserScriptListener()), #endif prerender_tracker_(prerender_tracker) { + BrowserThread::PostTask( + BrowserThread::IO, + FROM_HERE, + base::Bind(content::ServiceWorkerContext::AddExcludedHeadersForFetchEvent, + variations::VariationsHttpHeaderProvider::GetInstance() + ->GetVariationHeaderNames())); } ChromeResourceDispatcherHostDelegate::~ChromeResourceDispatcherHostDelegate() { |