diff options
author | jochen@chromium.org <jochen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-05-08 23:25:22 +0000 |
---|---|---|
committer | jochen@chromium.org <jochen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-05-08 23:25:22 +0000 |
commit | adbda59b25a349bab5df95cb86c1e42b9b0ed333 (patch) | |
tree | 25e1cc15ad3f3d2427884e173ebe71512028879d /webkit | |
parent | 04a8c1ae5038f7c67582fc9295c9c4eac4d61caf (diff) | |
download | chromium_src-adbda59b25a349bab5df95cb86c1e42b9b0ed333.zip chromium_src-adbda59b25a349bab5df95cb86c1e42b9b0ed333.tar.gz chromium_src-adbda59b25a349bab5df95cb86c1e42b9b0ed333.tar.bz2 |
Allow for overriding the handling of the referrer header in the network stack
When a non-default referrer policy is effective, the network stack should not
mess with the header
BUG=124750
TEST=the test for that code path is disabled :-/
Review URL: https://chromiumcodereview.appspot.com/10309005
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@135943 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit')
-rw-r--r-- | webkit/glue/webkit_glue.cc | 19 | ||||
-rw-r--r-- | webkit/glue/webkit_glue.h | 9 | ||||
-rw-r--r-- | webkit/tools/test_shell/simple_resource_loader_bridge.cc | 5 |
3 files changed, 33 insertions, 0 deletions
diff --git a/webkit/glue/webkit_glue.cc b/webkit/glue/webkit_glue.cc index 496b837..c2ee25b 100644 --- a/webkit/glue/webkit_glue.cc +++ b/webkit/glue/webkit_glue.cc @@ -24,6 +24,7 @@ #include "base/sys_string_conversions.h" #include "base/utf_string_conversions.h" #include "net/base/escape.h" +#include "net/url_request/url_request.h" #include "skia/ext/platform_canvas.h" #if defined(OS_MACOSX) #include "skia/ext/skia_utils_mac.h" @@ -498,4 +499,22 @@ bool IsInspectorProtocolVersionSupported(const std::string& version) { WebString::fromUTF8(version)); } +void ConfigureURLRequestForReferrerPolicy( + net::URLRequest* request, WebKit::WebReferrerPolicy referrer_policy) { + net::URLRequest::ReferrerPolicy net_referrer_policy; + switch (referrer_policy) { + case WebKit::WebReferrerPolicyDefault: + net_referrer_policy = + net::URLRequest::CLEAR_REFERRER_ON_TRANSITION_FROM_SECURE_TO_INSECURE; + break; + + case WebKit::WebReferrerPolicyAlways: + case WebKit::WebReferrerPolicyNever: + case WebKit::WebReferrerPolicyOrigin: + net_referrer_policy = net::URLRequest::NEVER_CLEAR_REFERRER; + break; + } + request->set_referrer_policy(net_referrer_policy); +} + } // namespace webkit_glue diff --git a/webkit/glue/webkit_glue.h b/webkit/glue/webkit_glue.h index 1dae5f3..fa2bb7d 100644 --- a/webkit/glue/webkit_glue.h +++ b/webkit/glue/webkit_glue.h @@ -18,12 +18,17 @@ #include "base/platform_file.h" #include "base/string16.h" #include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebCanvas.h" +#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebReferrerPolicy.h" #include "third_party/WebKit/Source/WebKit/chromium/public/WebFileError.h" #include "webkit/glue/webkit_glue_export.h" class GURL; class SkBitmap; +namespace net { +class URLRequest; +} + namespace skia { class PlatformCanvas; } @@ -154,6 +159,10 @@ std::string GetInspectorProtocolVersion(); WEBKIT_GLUE_EXPORT bool IsInspectorProtocolVersionSupported( const std::string& version); +// Configures the URLRequest according to the referrer policy. +WEBKIT_GLUE_EXPORT void ConfigureURLRequestForReferrerPolicy( + net::URLRequest* request, WebKit::WebReferrerPolicy referrer_policy); + } // namespace webkit_glue #endif // WEBKIT_GLUE_WEBKIT_GLUE_H_ diff --git a/webkit/tools/test_shell/simple_resource_loader_bridge.cc b/webkit/tools/test_shell/simple_resource_loader_bridge.cc index 6d5865a..074580d 100644 --- a/webkit/tools/test_shell/simple_resource_loader_bridge.cc +++ b/webkit/tools/test_shell/simple_resource_loader_bridge.cc @@ -68,6 +68,7 @@ #include "webkit/fileapi/file_system_dir_url_request_job.h" #include "webkit/fileapi/file_system_url_request_job.h" #include "webkit/glue/resource_loader_bridge.h" +#include "webkit/glue/webkit_glue.h" #include "webkit/tools/test_shell/simple_appcache_system.h" #include "webkit/tools/test_shell/simple_file_system.h" #include "webkit/tools/test_shell/simple_file_writer.h" @@ -260,6 +261,7 @@ struct RequestParams { GURL url; GURL first_party_for_cookies; GURL referrer; + WebKit::WebReferrerPolicy referrer_policy; std::string headers; int load_flags; ResourceType::Type request_type; @@ -411,6 +413,8 @@ class RequestProxy request_->set_method(params->method); request_->set_first_party_for_cookies(params->first_party_for_cookies); request_->set_referrer(params->referrer.spec()); + webkit_glue::ConfigureURLRequestForReferrerPolicy( + request_.get(), params->referrer_policy); net::HttpRequestHeaders headers; headers.AddHeadersFromString(params->headers); request_->SetExtraRequestHeaders(headers); @@ -840,6 +844,7 @@ class ResourceLoaderBridgeImpl : public ResourceLoaderBridge { params_->url = request_info.url; params_->first_party_for_cookies = request_info.first_party_for_cookies; params_->referrer = request_info.referrer; + params_->referrer_policy = request_info.referrer_policy; params_->headers = request_info.headers; params_->load_flags = request_info.load_flags; params_->request_type = request_info.request_type; |