From aad4dea917bdacc44f62b5178e9bb34eb1ad2789 Mon Sep 17 00:00:00 2001 From: Cameron Kaiser Date: Thu, 10 Aug 2017 21:19:38 -0700 Subject: [PATCH] #422: bite me imgur --- netwerk/protocol/http/HttpBaseChannel.cpp | 3 ++- netwerk/protocol/http/nsHttpHandler.cpp | 24 ++++++++++++++++++----- netwerk/protocol/http/nsHttpHandler.h | 3 ++- 3 files changed, 23 insertions(+), 7 deletions(-) diff --git a/netwerk/protocol/http/HttpBaseChannel.cpp b/netwerk/protocol/http/HttpBaseChannel.cpp index c430ad085..183684b68 100644 --- a/netwerk/protocol/http/HttpBaseChannel.cpp +++ b/netwerk/protocol/http/HttpBaseChannel.cpp @@ -181,7 +181,8 @@ HttpBaseChannel::Init(nsIURI *aURI, rv = mRequestHead.SetHeader(nsHttp::Host, hostLine); if (NS_FAILED(rv)) return rv; - rv = gHttpHandler->AddStandardRequestHeaders(&mRequestHead.Headers(), isHTTPS); + rv = gHttpHandler->AddStandardRequestHeaders(&mRequestHead.Headers(), isHTTPS, +hostLine); if (NS_FAILED(rv)) return rv; nsAutoCString type; diff --git a/netwerk/protocol/http/nsHttpHandler.cpp b/netwerk/protocol/http/nsHttpHandler.cpp index 7c50cfe94..d118a488d 100644 --- a/netwerk/protocol/http/nsHttpHandler.cpp +++ b/netwerk/protocol/http/nsHttpHandler.cpp @@ -422,14 +422,28 @@ nsHttpHandler::InitConnectionMgr() } nsresult -nsHttpHandler::AddStandardRequestHeaders(nsHttpHeaderArray *request, bool isSecure) +nsHttpHandler::AddStandardRequestHeaders(nsHttpHeaderArray *request, + bool isSecure, + const nsACString &hostLine) { nsresult rv; - // Add the "User-Agent" header - rv = request->SetHeader(nsHttp::User_Agent, UserAgent(), - false, nsHttpHeaderArray::eVarietyDefault); - if (NS_FAILED(rv)) return rv; + // Add the "User-Agent" header (unless we have blacklisted this site and + // we aren't using a custom user agent; see TenFourFox issue 422). + if (mUserAgentOverride || ( + !hostLine.EqualsLiteral("i.imgur.com") && + !hostLine.EqualsLiteral("imgur.com") && + 1)) { + rv = request->SetHeader(nsHttp::User_Agent, UserAgent(), + false, nsHttpHeaderArray::eVarietyDefault); + if (NS_FAILED(rv)) return rv; + } +#if DEBUG + else { + fprintf(stderr, "User agent header suppressed for host: %s\n", + PromiseFlatCString(hostLine).get()); + } +#endif // MIME based content negotiation lives! // Add the "Accept" header. Note, this is set as an override because the diff --git a/netwerk/protocol/http/nsHttpHandler.h b/netwerk/protocol/http/nsHttpHandler.h index 6bd27389e..0e825700c 100644 --- a/netwerk/protocol/http/nsHttpHandler.h +++ b/netwerk/protocol/http/nsHttpHandler.h @@ -67,7 +67,8 @@ public: nsHttpHandler(); nsresult Init(); - nsresult AddStandardRequestHeaders(nsHttpHeaderArray *, bool isSecure); + nsresult AddStandardRequestHeaders(nsHttpHeaderArray *, bool isSecure, + const nsACString &hostLine); nsresult AddConnectionHeader(nsHttpHeaderArray *, uint32_t capabilities); bool IsAcceptableEncoding(const char *encoding, bool isSecure);