summaryrefslogtreecommitdiffstats
path: root/chrome/browser/renderer_host/chrome_resource_dispatcher_host_delegate.cc
diff options
context:
space:
mode:
authorhoro <horo@chromium.org>2014-10-31 19:08:28 -0700
committerCommit bot <commit-bot@chromium.org>2014-11-01 02:08:43 +0000
commite09b6c8616f4a8e45e91a171eedddefde9522ac2 (patch)
treea2bf42602693c66c8d5089e68aca52f7ae788d9a /chrome/browser/renderer_host/chrome_resource_dispatcher_host_delegate.cc
parent2178ec8cf854f0996a2d66649f52841e1ed18795 (diff)
downloadchromium_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.cc7
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() {