blob: 28bf48b89a321a6212331f99ad8fadf39b5a9afc [file] [log] [blame]
// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_SECURITY_INTERSTITIALS_CONTENT_SSL_ERROR_NAVIGATION_THROTTLE_H_
#define COMPONENTS_SECURITY_INTERSTITIALS_CONTENT_SSL_ERROR_NAVIGATION_THROTTLE_H_
#include <memory>
#include "base/memory/weak_ptr.h"
#include "content/public/browser/certificate_request_result_type.h"
#include "content/public/browser/navigation_throttle.h"
#include "net/ssl/ssl_info.h"
class GURL;
namespace content {
class NavigationHandle;
class NavigationThrottleRegistry;
class WebContents;
} // namespace content
namespace security_interstitials {
class SecurityInterstitialPage;
} // namespace security_interstitials
// SSLErrorNavigationThrottle watches for failed navigations that should be
// displayed as SSL interstitial pages. More specifically,
// SSLErrorNavigationThrottle::WillFailRequest() will defer any navigations that
// failed due to a certificate error. After calculating which interstitial to
// show, it will cancel the navigation with the interstitial's custom error page
// HTML.
class SSLErrorNavigationThrottle : public content::NavigationThrottle {
public:
typedef base::OnceCallback<void(
content::WebContents* web_contents,
int cert_error,
const net::SSLInfo& ssl_info,
const GURL& request_url,
base::OnceCallback<void(
std::unique_ptr<security_interstitials::SecurityInterstitialPage>)>
blocking_page_ready_callback)>
HandleSSLErrorCallback;
// Returns whether |web_contents| is in the context of a hosted app, as the
// logic of when to display interstitials for SSL errors is specialized for
// hosted apps. This is exposed as a callback because although the WebContents
// is known at the time of creating SSLErrorNavigationThrottle, it may not
// have been inserted into a browser by the time the navigation begins. See
// browser_navigator.cc.
typedef base::OnceCallback<bool(content::WebContents* web_contents)>
IsInHostedAppCallback;
typedef base::OnceCallback<bool(content::NavigationHandle* handle)>
ShouldIgnoreInterstitialBecauseNavigationDefaultedToHttpsCallback;
SSLErrorNavigationThrottle(
content::NavigationThrottleRegistry& registry,
HandleSSLErrorCallback handle_ssl_error_callback,
IsInHostedAppCallback is_in_hosted_app_callback,
ShouldIgnoreInterstitialBecauseNavigationDefaultedToHttpsCallback
should_ignore_interstitial_because_navigation_defaulted_to_https_callback);
~SSLErrorNavigationThrottle() override;
// content::NavigationThrottle:
ThrottleCheckResult WillFailRequest() override;
ThrottleCheckResult WillProcessResponse() override;
const char* GetNameForLogging() override;
private:
void QueueShowInterstitial(HandleSSLErrorCallback handle_ssl_error_callback,
content::WebContents* web_contents,
int net_error,
int cert_status,
const net::SSLInfo& ssl_info,
const GURL& request_url);
void ShowInterstitial(
int net_error,
std::unique_ptr<security_interstitials::SecurityInterstitialPage>
blocking_page);
HandleSSLErrorCallback handle_ssl_error_callback_;
IsInHostedAppCallback is_in_hosted_app_callback_;
ShouldIgnoreInterstitialBecauseNavigationDefaultedToHttpsCallback
should_ignore_interstitial_because_navigation_defaulted_to_https_callback_;
base::WeakPtrFactory<SSLErrorNavigationThrottle> weak_ptr_factory_{this};
};
#endif // COMPONENTS_SECURITY_INTERSTITIALS_CONTENT_SSL_ERROR_NAVIGATION_THROTTLE_H_