summaryrefslogtreecommitdiffstats
path: root/chrome_frame/http_negotiate.cc
diff options
context:
space:
mode:
authortommi@chromium.org <tommi@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-04-19 17:01:06 +0000
committertommi@chromium.org <tommi@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-04-19 17:01:06 +0000
commit98f8aa41c9351d34ee6e9e774922ba1fd66f7155 (patch)
tree97ad60c19c27747261bfde030282e31bdb29a595 /chrome_frame/http_negotiate.cc
parent91f4caabc045b18d0897d7f3a10bf95baa6d842d (diff)
downloadchromium_src-98f8aa41c9351d34ee6e9e774922ba1fd66f7155.zip
chromium_src-98f8aa41c9351d34ee6e9e774922ba1fd66f7155.tar.gz
chromium_src-98f8aa41c9351d34ee6e9e774922ba1fd66f7155.tar.bz2
Revert 44897 - Improved compatibility support for IE8.
1) We no longer add a user agent to requests that do not already have one. This will result in the correct user agent header being applied but it will not have the chromeframe tag. Requests that will be affected include requests from other plugins and XHR but not top level requests. 2) Requests from Chrome Frame will always have the native user agent applied regardless of compatibility settings. This means that in IE8, you will always see CF requests with MSIE 8.0 even though the target site is otherwise configured to run in IE7 compatibility. TEST=Make sure all CF websites continue to work properly. Also, turn on IE7 compatibility mode for some websites (e.g. wave, vimeo) and check if the user agent sent to those sites contains "MSIE 7.0" for pages that are not rendered in CF. Pages rendered in CF should always have the IE8 header with the possible exception of the very first request if that request was issued by mshtml. BUG=28816 Review URL: http://codereview.chromium.org/1521037 TBR=tommi@chromium.org Review URL: http://codereview.chromium.org/1659008 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@44919 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome_frame/http_negotiate.cc')
-rw-r--r--chrome_frame/http_negotiate.cc18
1 files changed, 10 insertions, 8 deletions
diff --git a/chrome_frame/http_negotiate.cc b/chrome_frame/http_negotiate.cc
index cc9606e..a95255a 100644
--- a/chrome_frame/http_negotiate.cc
+++ b/chrome_frame/http_negotiate.cc
@@ -258,6 +258,14 @@ HRESULT HttpNegotiatePatch::BeginningTransaction(
user_agent_value = original_it.values();
}
+ // Use the default one if none was provided.
+ if (user_agent_value.empty())
+ user_agent_value = http_utils::GetDefaultUserAgent();
+
+ // Now add chromeframe to it.
+ user_agent_value = http_utils::AddChromeFrameToUserAgentValue(
+ user_agent_value);
+
// Build new headers, skip the existing user agent value from
// existing headers.
std::string new_headers;
@@ -269,17 +277,11 @@ HRESULT HttpNegotiatePatch::BeginningTransaction(
}
}
- if (!user_agent_value.empty()) {
- // Now add chromeframe to the user agent.
- user_agent_value = http_utils::AddChromeFrameToUserAgentValue(
- user_agent_value);
- new_headers += "User-Agent: " + user_agent_value;
- new_headers += "\r\n\r\n";
- }
+ new_headers += "User-Agent: " + user_agent_value;
+ new_headers += "\r\n\r\n";
if (*additional_headers)
::CoTaskMemFree(*additional_headers);
-
*additional_headers = reinterpret_cast<wchar_t*>(::CoTaskMemAlloc(
(new_headers.length() + 1) * sizeof(wchar_t)));
lstrcpyW(*additional_headers, ASCIIToWide(new_headers).c_str());