1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
|
// Copyright 2020 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "components/payments/content/payment_handler_navigation_throttle.h"
#include <cstddef>
#include <string>
#include "components/payments/content/payments_userdata_key.h"
#include "content/public/browser/navigation_handle.h"
#include "content/public/browser/navigation_throttle.h"
#include "content/public/browser/web_contents.h"
#include "net/http/http_response_headers.h"
namespace payments {
constexpr char kApplicationJavascript[] = "application/javascript";
constexpr char kApplicationXml[] = "application/xml";
constexpr char kApplicationJson[] = "application/json";
PaymentHandlerNavigationThrottle::PaymentHandlerNavigationThrottle(
content::NavigationThrottleRegistry& registry)
: content::NavigationThrottle(registry) {}
PaymentHandlerNavigationThrottle::~PaymentHandlerNavigationThrottle() = default;
const char* PaymentHandlerNavigationThrottle::GetNameForLogging() {
return "PaymentHandlerNavigationThrottle";
}
// static
void PaymentHandlerNavigationThrottle::MarkPaymentHandlerWebContents(
content::WebContents* web_contents) {
if (!web_contents) {
return;
}
web_contents->SetUserData(kPaymentHandlerWebContentsUserDataKey,
std::make_unique<base::SupportsUserData::Data>());
}
// static
void PaymentHandlerNavigationThrottle::MaybeCreateAndAdd(
content::NavigationThrottleRegistry& registry) {
content::NavigationHandle& handle = registry.GetNavigationHandle();
if (!handle.GetWebContents() || !handle.GetWebContents()->GetUserData(
kPaymentHandlerWebContentsUserDataKey)) {
return;
}
registry.AddThrottle(
std::make_unique<PaymentHandlerNavigationThrottle>(registry));
}
content::NavigationThrottle::ThrottleCheckResult
PaymentHandlerNavigationThrottle::WillProcessResponse() {
if (!navigation_handle()) {
return PROCEED;
}
const net::HttpResponseHeaders* response_headers =
navigation_handle()->GetResponseHeaders();
if (!response_headers) {
return PROCEED;
}
std::string mime_type;
response_headers->GetMimeType(&mime_type);
// This allowlist is made to exclude edge-cases whose vulnerabilities could
// be exploited (e.g., application/pdf, see crbug.com/1159267).
if (base::StartsWith(mime_type, "text/",
base::CompareCase::INSENSITIVE_ASCII) ||
base::StartsWith(mime_type, "image/",
base::CompareCase::INSENSITIVE_ASCII) ||
base::StartsWith(mime_type, "video/",
base::CompareCase::INSENSITIVE_ASCII) ||
mime_type == kApplicationJavascript || mime_type == kApplicationXml ||
mime_type == kApplicationJson) {
return PROCEED;
}
VLOG(0) << "Blocked the payment handler from navigating to a page "
<< navigation_handle()->GetURL().spec() << " of " << mime_type
<< " mime type.";
return BLOCK_RESPONSE;
}
} // namespace payments
|