| Index: chrome/browser/ssl/ssl_error_handler.h
|
| diff --git a/chrome/browser/ssl/ssl_error_handler.h b/chrome/browser/ssl/ssl_error_handler.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..d15a161061008781d298a99387aeee24bf5d62c0
|
| --- /dev/null
|
| +++ b/chrome/browser/ssl/ssl_error_handler.h
|
| @@ -0,0 +1,108 @@
|
| +// Copyright 2014 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.
|
| +
|
| +#ifndef CHROME_BROWSER_SSL_SSL_ERROR_HANDLER_H_
|
| +#define CHROME_BROWSER_SSL_SSL_ERROR_HANDLER_H_
|
| +
|
| +#include <string>
|
| +
|
| +#include "base/callback_forward.h"
|
| +#include "base/macros.h"
|
| +#include "base/timer/timer.h"
|
| +#include "chrome/browser/chrome_notification_types.h"
|
| +#include "content/public/browser/notification_observer.h"
|
| +#include "content/public/browser/notification_registrar.h"
|
| +#include "content/public/browser/web_contents_observer.h"
|
| +#include "net/ssl/ssl_info.h"
|
| +#include "url/gurl.h"
|
| +
|
| +namespace content {
|
| +class RenderViewHost;
|
| +class WebContents;
|
| +}
|
| +
|
| +// This class is responsible for deciding whether to show an SSL warning or a
|
| +// captive portal error page. It makes this decision by delaying the display of
|
| +// SSL interstitial for a few seconds (2 by default), and waiting for a captive
|
| +// portal result to arrive during this window. If a captive portal detected
|
| +// result arrives in this window, a captive portal error page is shown.
|
| +// Otherwise, an SSL interstitial is shown.
|
| +//
|
| +// This class deletes itself when the interstitial page is closed. It should
|
| +// only be used on the UI thread because its implementation uses
|
| +// captive_portal::CaptivePortalService which can only be accessed on the UI
|
| +// thread.
|
| +class SSLErrorHandler : public content::WebContentsObserver,
|
| + public content::NotificationObserver {
|
| + public:
|
| + SSLErrorHandler(content::WebContents* web_contents,
|
| + int cert_error,
|
| + const net::SSLInfo& ssl_info,
|
| + const GURL& request_url,
|
| + int options_mask,
|
| + const base::Callback<void(bool)>& callback);
|
| + ~SSLErrorHandler() override;
|
| +
|
| + static void HandleSSLError(content::WebContents* web_contents,
|
| + int cert_error,
|
| + const net::SSLInfo& ssl_info,
|
| + const GURL& request_url,
|
| + int options_mask,
|
| + const base::Callback<void(bool)>& callback);
|
| +
|
| + static void SetInterstitialDisplayDelayForTest(
|
| + base::TimeDelta interstitial_display_delay) {
|
| + interstitial_display_delay_ = interstitial_display_delay;
|
| + }
|
| +
|
| + protected:
|
| + // Called when an SSL cert error is encountered. Triggers a captive portal
|
| + // check and fires a one shot timer to wait for a "captive portal detected"
|
| + // result to arrive.
|
| + void StartHandlingError();
|
| + const base::OneShotTimer<SSLErrorHandler>& get_timer() const {
|
| + return timer_;
|
| + }
|
| +
|
| + private:
|
| + // Time to wait before displaying the SSL interstitial. If a captive portal
|
| + // arrives before this, the captive portal interstitial is displayed instead.
|
| + static base::TimeDelta interstitial_display_delay_;
|
| +
|
| + // Callback for the one-shot timer. When the timer expires, an SSL error is
|
| + // immediately displayed.
|
| + void OnTimerExpired();
|
| +
|
| + // These are virtual for tests:
|
| + virtual void CheckForCaptivePortal();
|
| + virtual void ShowCaptivePortalInterstitial();
|
| + virtual void ShowSSLInterstitial();
|
| +
|
| + // content::NotificationObserver:
|
| + void Observe(
|
| + int type,
|
| + const content::NotificationSource& source,
|
| + const content::NotificationDetails& details) override;
|
| +
|
| + // content::WebContentsObserver:
|
| + void DidStartNavigationToPendingEntry(
|
| + const GURL& url,
|
| + content::NavigationController::ReloadType reload_type) override;
|
| + void DidStopLoading(
|
| + content::RenderViewHost* render_view_host) override;
|
| + void WebContentsDestroyed() override;
|
| +
|
| + const int cert_error_;
|
| + const net::SSLInfo ssl_info_;
|
| + const GURL request_url_;
|
| + const int options_mask_;
|
| + const base::Callback<void(bool)> callback_;
|
| +
|
| + content::NotificationRegistrar registrar_;
|
| + base::OneShotTimer<SSLErrorHandler> timer_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(SSLErrorHandler);
|
| +};
|
| +
|
| +#endif // CHROME_BROWSER_SSL_SSL_ERROR_HANDLER_H_
|
|
|