diff options
Diffstat (limited to 'webkit')
-rw-r--r-- | webkit/glue/resource_loader_bridge.h | 17 | ||||
-rw-r--r-- | webkit/glue/weburlloader_impl.cc | 26 |
2 files changed, 42 insertions, 1 deletions
diff --git a/webkit/glue/resource_loader_bridge.h b/webkit/glue/resource_loader_bridge.h index eae1404..99824b4 100644 --- a/webkit/glue/resource_loader_bridge.h +++ b/webkit/glue/resource_loader_bridge.h @@ -17,6 +17,9 @@ #ifndef WEBKIT_GLUE_RESOURCE_LOADER_BRIDGE_H_ #define WEBKIT_GLUE_RESOURCE_LOADER_BRIDGE_H_ +#include <utility> +#include <vector> + #include "build/build_config.h" #if defined(OS_POSIX) #include "base/file_descriptor_posix.h" @@ -24,7 +27,9 @@ #include "base/file_path.h" #include "base/platform_file.h" #include "base/ref_counted.h" +#include "base/scoped_ptr.h" #include "base/time.h" +#include "base/values.h" #include "googleurl/src/gurl.h" #include "net/url_request/url_request_status.h" #include "webkit/glue/resource_type.h" @@ -147,6 +152,13 @@ class ResourceLoaderBridge { int32 receive_headers_end; }; + struct DevToolsInfo : base::RefCounted<DevToolsInfo> { + typedef std::vector<std::pair<std::string, std::string> > + HeadersVector; + HeadersVector request_headers; + HeadersVector response_headers; + }; + struct ResponseInfo { ResponseInfo(); ~ResponseInfo(); @@ -194,6 +206,11 @@ class ResourceLoaderBridge { // Tools. LoadTimingInfo load_timing; + // Actual request and response headers, as obtained from the network stack. + // Only present if request had LOAD_REPORT_RAW_HEADERS in load_flags, and + // requesting renderer had CanReadRowCookies permission. + scoped_refptr<DevToolsInfo> devtools_info; + // The path to a file that will contain the response body. It may only // contain a portion of the response body at the time that the ResponseInfo // becomes available. diff --git a/webkit/glue/weburlloader_impl.cc b/webkit/glue/weburlloader_impl.cc index ad3e5fe..528cc19 100644 --- a/webkit/glue/weburlloader_impl.cc +++ b/webkit/glue/weburlloader_impl.cc @@ -18,6 +18,7 @@ #include "net/base/net_util.h" #include "net/http/http_response_headers.h" #include "third_party/WebKit/WebKit/chromium/public/WebHTTPHeaderVisitor.h" +#include "third_party/WebKit/WebKit/chromium/public/WebResourceRawHeaders.h" #include "third_party/WebKit/WebKit/chromium/public/WebSecurityPolicy.h" #include "third_party/WebKit/WebKit/chromium/public/WebURL.h" #include "third_party/WebKit/WebKit/chromium/public/WebURLError.h" @@ -36,6 +37,7 @@ using base::TimeDelta; using WebKit::WebData; using WebKit::WebHTTPBody; using WebKit::WebHTTPHeaderVisitor; +using WebKit::WebResourceRawHeaders; using WebKit::WebSecurityPolicy; using WebKit::WebString; using WebKit::WebURL; @@ -163,6 +165,8 @@ bool GetInfoFromDataURL(const GURL& url, return false; } +typedef ResourceLoaderBridge::DevToolsInfo::HeadersVector HeadersVector; + void PopulateURLResponse( const GURL& url, const ResourceLoaderBridge::ResponseInfo& info, @@ -203,6 +207,25 @@ void PopulateURLResponse( timing.setReceiveHeadersEnd(timing_info.receive_headers_end); response->setLoadTiming(timing); + if (info.devtools_info.get()) { + WebResourceRawHeaders rawHeaders; + + const HeadersVector& request_headers = info.devtools_info->request_headers; + for (HeadersVector::const_iterator it = request_headers .begin(); + it != request_headers.end(); ++it) { + rawHeaders.addRequestHeader(WebString::fromUTF8(it->first), + WebString::fromUTF8(it->second)); + } + const HeadersVector& response_headers = + info.devtools_info->response_headers; + for (HeadersVector::const_iterator it = response_headers.begin(); + it != response_headers.end(); ++it) { + rawHeaders.addResponseHeader(WebString::fromUTF8(it->first), + WebString::fromUTF8(it->second)); + } + response->setResourceRawHeaders(rawHeaders); + } + const net::HttpResponseHeaders* headers = info.headers; if (!headers) return; @@ -364,6 +387,8 @@ void WebURLLoaderImpl::Context::Start( load_flags |= net::LOAD_ENABLE_UPLOAD_PROGRESS; if (request.reportLoadTiming()) load_flags |= net::LOAD_ENABLE_LOAD_TIMING; + if (request.reportRawHeaders()) + load_flags |= net::LOAD_REPORT_RAW_HEADERS; if (!request.allowCookies() || !request.allowStoredCredentials()) { load_flags |= net::LOAD_DO_NOT_SAVE_COOKIES; @@ -373,7 +398,6 @@ void WebURLLoaderImpl::Context::Start( if (!request.allowStoredCredentials()) load_flags |= net::LOAD_DO_NOT_SEND_AUTH_DATA; - // TODO(jcampan): in the non out-of-process plugin case the request does not // have a requestor_pid. Find a better place to set this. int requestor_pid = request.requestorProcessID(); |