| Index: chrome/browser/security/xfo_throttle.cc
|
| diff --git a/chrome/browser/security/xfo_throttle.cc b/chrome/browser/security/xfo_throttle.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..7708e0d0a09df15f55f7f46641ff1eccccc613ee
|
| --- /dev/null
|
| +++ b/chrome/browser/security/xfo_throttle.cc
|
| @@ -0,0 +1,72 @@
|
| +// Copyright 2015 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#include "chrome/browser/security/xfo_throttle.h"
|
| +
|
| +#include "base/strings/string_util.h"
|
| +#include "content/public/browser/navigation_handle.h"
|
| +#include "content/public/browser/navigation_throttle.h"
|
| +#include "net/http/http_response_headers.h"
|
| +
|
| +// static
|
| +scoped_ptr<NavigationThrottle> XFOThrottle::MaybeCreateThrottleFor(
|
| + NavigationHandle* handle) {
|
| + DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
|
| +
|
| + if (handle->IsInMainFrame())
|
| + return nullptr;
|
| +
|
| + return scoped_ptr<NavigationThrottle>(new XFOThrottle(handle));
|
| +}
|
| +
|
| +XFOThrottle::XFOThrottle(NavigationHandle* handle)
|
| + : NavigationThrottle(handle) {}
|
| +
|
| +XFOThrottle::~XFOThrottle() {}
|
| +
|
| +NavigationThrottle::ThrottleCheckResult XFOThrottle::WillProcessResponse() {
|
| + DCHECK(!navigation_handle()->IsInMainFrame());
|
| +
|
| + HeaderDisposition disposition =
|
| + ParseHeader(navigation_handle()->GetResponseHeaders());
|
| + switch (disposition) {
|
| + case DENY:
|
| + case CONFLICT:
|
| + case INVALID:
|
| + return NavigationThrottle::CANCEL_AND_IGNORE;
|
| +
|
| + default:
|
| + return NavigationThrottle::PROCEED;
|
| + }
|
| + return NavigationThrottle::PROCEED;
|
| +}
|
| +
|
| +XFOThrottle::HeaderDisposition XFOThrottle::ParseHeader(
|
| + const net::HttpResponseHeaders* headers) {
|
| + if (!headers)
|
| + return NOT_PRESENT;
|
| +
|
| + void* iter = nullptr;
|
| + std::string value;
|
| + HeaderDisposition result = NOT_PRESENT;
|
| + while (headers->EnumerateHeader(&iter, "x-frame-options", &value)) {
|
| + HeaderDisposition current = INVALID;
|
| + base::StringPiece trimmed =
|
| + base::TrimWhitespaceASCII(value, base::TRIM_ALL);
|
| + if (base::LowerCaseEqualsASCII(trimmed, "deny"))
|
| + current = DENY;
|
| + else if (base::LowerCaseEqualsASCII(trimmed, "allowall"))
|
| + current = ALLOWALL;
|
| + else if (base::LowerCaseEqualsASCII(trimmed, "sameorigin"))
|
| + current = SAMEORIGIN;
|
| +
|
| + if (result == NOT_PRESENT)
|
| + result = current;
|
| + else if (result == current)
|
| + continue;
|
| + else
|
| + return CONFLICT;
|
| + }
|
| + return result;
|
| +}
|
|
|