summaryrefslogtreecommitdiffstats
path: root/net/url_request/url_request_job.cc
diff options
context:
space:
mode:
authorjar@google.com <jar@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-10-15 21:21:37 +0000
committerjar@google.com <jar@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-10-15 21:21:37 +0000
commitc631b6aabef4753d124fcda8fcd1ea3d6931803d (patch)
tree2d35566d0b4a6ea39c421c7b7bab9a42a1b6b15f /net/url_request/url_request_job.cc
parent9e82059e9496cd01dc4766197196c9d3330fa842 (diff)
downloadchromium_src-c631b6aabef4753d124fcda8fcd1ea3d6931803d.zip
chromium_src-c631b6aabef4753d124fcda8fcd1ea3d6931803d.tar.gz
chromium_src-c631b6aabef4753d124fcda8fcd1ea3d6931803d.tar.bz2
Add a lot of robustness to SDCH filter decoding
a) Do meta-refresh (and partially disable sdch) when we have an sdch decode error early on (due to lack of dictionary). b) Gracefully handle proxy removal of "gzip" in "content-encoding: sdch,gzip". c) Recover from completely stripped content encoding (in response to a request for which we advertised an SDCH dictionary) by using a filter that can optionally decode sdch with an optional gzip as well. Some field tests have shown problems with this protocol's transit across the ether. The general approach we've adopted is to stop using SDCH on the problematic site when we have problems. This will prevent a malicious site from shutting down all use of SDCH. r=kmixter,openvcdiff,huanr Review URL: http://codereview.chromium.org/6433 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@3420 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/url_request/url_request_job.cc')
-rw-r--r--net/url_request/url_request_job.cc4
1 files changed, 3 insertions, 1 deletions
diff --git a/net/url_request/url_request_job.cc b/net/url_request/url_request_job.cc
index 0501286..f4924bb 100644
--- a/net/url_request/url_request_job.cc
+++ b/net/url_request/url_request_job.cc
@@ -52,8 +52,10 @@ void URLRequestJob::SetupFilter() {
std::string mime_type;
GetMimeType(&mime_type);
filter_.reset(Filter::Factory(encoding_types, mime_type, kFilterBufSize));
- if (filter_.get())
+ if (filter_.get()) {
filter_->SetURL(request_->url());
+ filter_->SetMimeType(mime_type);
+ }
}
}