| Index: content/browser/frame_host/form_submission_throttle.cc
|
| diff --git a/content/browser/frame_host/form_submission_throttle.cc b/content/browser/frame_host/form_submission_throttle.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..8e3958f5c5e67aa4bdf14bf5bb791aa7468c6963
|
| --- /dev/null
|
| +++ b/content/browser/frame_host/form_submission_throttle.cc
|
| @@ -0,0 +1,65 @@
|
| +// Copyright 2017 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 "content/browser/frame_host/form_submission_throttle.h"
|
| +#include "content/browser/frame_host/navigation_handle_impl.h"
|
| +#include "content/public/browser/browser_thread.h"
|
| +#include "content/public/browser/navigation_handle.h"
|
| +#include "content/public/browser/navigation_throttle.h"
|
| +#include "content/public/common/browser_side_navigation_policy.h"
|
| +
|
| +namespace content {
|
| +
|
| +FormSubmissionThrottle::FormSubmissionThrottle(NavigationHandle* handle)
|
| + : NavigationThrottle(handle) {}
|
| +
|
| +// static
|
| +std::unique_ptr<NavigationThrottle>
|
| +FormSubmissionThrottle::MaybeCreateThrottleFor(NavigationHandle* handle) {
|
| + DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
|
| +
|
| + if (!IsBrowserSideNavigationEnabled())
|
| + return nullptr;
|
| +
|
| + NavigationHandleImpl* handle_impl =
|
| + static_cast<NavigationHandleImpl*>(handle);
|
| +
|
| + if (!handle_impl->is_form_submission())
|
| + return nullptr;
|
| +
|
| + return std::unique_ptr<NavigationThrottle>(
|
| + new FormSubmissionThrottle(handle));
|
| +}
|
| +
|
| +FormSubmissionThrottle::~FormSubmissionThrottle() {}
|
| +
|
| +NavigationThrottle::ThrottleCheckResult
|
| +FormSubmissionThrottle::WillStartRequest() {
|
| + return CheckContentSecurityPolicyFormAction(false /* is_redirect */);
|
| +}
|
| +
|
| +NavigationThrottle::ThrottleCheckResult
|
| +FormSubmissionThrottle::WillRedirectRequest() {
|
| + return CheckContentSecurityPolicyFormAction(true /* is_redirect */);
|
| +}
|
| +
|
| +NavigationThrottle::ThrottleCheckResult
|
| +FormSubmissionThrottle::CheckContentSecurityPolicyFormAction(bool is_redirect) {
|
| + NavigationHandleImpl* handle =
|
| + static_cast<NavigationHandleImpl*>(navigation_handle());
|
| +
|
| + if (handle->should_check_main_world_csp() == CSPDisposition::DO_NOT_CHECK)
|
| + return NavigationThrottle::PROCEED;
|
| +
|
| + const GURL& url = handle->GetURL();
|
| + RenderFrameHostImpl* render_frame =
|
| + handle->frame_tree_node()->current_frame_host();
|
| +
|
| + if (render_frame->IsAllowedByCsp(CSPDirective::FormAction, url, is_redirect))
|
| + return NavigationThrottle::PROCEED;
|
| +
|
| + return NavigationThrottle::CANCEL;
|
| +}
|
| +
|
| +} // namespace content
|
|
|