Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2994)

Unified Diff: chrome/browser/captive_portal/captive_portal_tab_helper.h

Issue 10020051: Open a login tab on captive portal detection on SSL loads. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Add missing file Created 8 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/captive_portal/captive_portal_tab_helper.h
===================================================================
--- chrome/browser/captive_portal/captive_portal_tab_helper.h (revision 0)
+++ chrome/browser/captive_portal/captive_portal_tab_helper.h (revision 0)
@@ -0,0 +1,174 @@
+// Copyright (c) 2012 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_CAPTIVE_PORTAL_CAPTIVE_PORTAL_TAB_HELPER_H_
+#define CHROME_BROWSER_CAPTIVE_PORTAL_CAPTIVE_PORTAL_TAB_HELPER_H_
+#pragma once
+
+#include "base/basictypes.h"
+#include "base/compiler_specific.h"
+#include "base/memory/weak_ptr.h"
+#include "base/threading/non_thread_safe.h"
+#include "base/time.h"
+#include "base/timer.h"
+#include "chrome/browser/captive_portal/captive_portal_tab_observer.h"
+#include "content/public/browser/notification_observer.h"
+#include "content/public/browser/notification_registrar.h"
+#include "content/public/browser/web_contents_observer.h"
+
+class Profile;
+class TabContentsWrapper;
+
+namespace captive_portal {
+
+// Class that keeps track of whether a tab is a login page or has encountered
cbentzel 2012/05/17 20:39:25 Nit: "Keeps track" instead of "Class that keeps tr
mmenke 2012/05/17 20:52:23 Done.
+// a navigation error caused by a captive portal. It triggers captive portal
+// checks and opens tabs at the portal's login page as necessary. All methods
+// may only be called on the UI thread.
+class CaptivePortalTabHelper : public content::NotificationObserver,
+ public base::NonThreadSafe {
+ public:
+ enum State {
+ STATE_NONE,
cbentzel 2012/05/17 20:39:25 It doesn't look like there is documentation here a
mmenke 2012/05/17 20:52:23 Done. Also added another link to the design doc (
+ // The slow load timer is running. Only started on SSL provisional loads.
+ // If the timer triggers before the page has been committed, a captive
+ // portal test will be requested.
+ STATE_TIMER_RUNNING,
+ // The tab may have been broken by a captive portal. A tab switches to
+ // this state either on an ERR_CONNECTION_TIMEOUT of an SSL page or when
+ // an SSL request takes too long to commit. The tab will remain in this
+ // state until the current load succeeds, a new provisional load starts,
+ // or it gets a captive portal result.
+ STATE_MAYBE_BROKEN_BY_PORTAL,
+ // The TabHelper switches to this state from STATE_MAYBE_BROKEN_BY_PORTAL in
+ // response a RESULT_BEHIND_CAPTIVE_PORTAL. The tab will remain in this
cbentzel 2012/05/17 20:39:25 Nit: response to
mmenke 2012/05/17 20:52:23 Done.
+ // state until a new provisional load starts, the original load successfully
+ // commits, the current load is aborted, or the tab reloads the page in
+ // response to receiving a captive portal result other than
+ // RESULT_BEHIND_CAPTIVE_PORTAL.
+ STATE_BROKEN_BY_PORTAL,
+ // The page may need to be reloaded. The tab will be reloaded if the page
+ // fails the next load with a timeout, or immediately upon switching to this
+ // state, if the page already timed out. If anything else happens
+ // when in this state (Another error, successful navigation, or the original
+ // navigation was aborted), the TabHelper transitions to STATE_NONE without
+ // reloading.
+ STATE_NEEDS_RELOAD,
+ // This tab is, or was, at the captive portal login page. This state is
+ // only cleared once the CaptivePortalService returns something other than
+ // RESULT_BEHIND_CAPTIVE_PORTAL.
+ STATE_CAPTIVE_PORTAL_LOGIN_PAGE,
+ };
+
+ // |profile| and |web_contents| will only be dereferenced in ReloadTab,
+ // MaybeOpenCaptivePortalLoginTab, and CheckForCaptivePortal, so they can
+ // both be NULL in the unit tests, though |profile| will still be used as a
+ // notification source.
+ CaptivePortalTabHelper(Profile* profile, content::WebContents* web_contents);
+
+ virtual ~CaptivePortalTabHelper();
+
+ protected:
+ // The following 4 functions are all invoked by |observer_|.
+
+ // Called when a non-error main frame load starts. Resets current state,
+ // unless this is a login tab. Each load will eventually result in a call to
+ // OnLoadCommitted or OnAbort. The former will be called both on successful
+ // loads and for error pages.
+ virtual void OnLoadStart(bool is_ssl);
+
+ // Called when a page is committed. |net_error| will be net::OK in the case
+ // of a successful load. For an errror page, the entire 3-step process of
+ // getting the error, starting a new provisional load for the error page, and
+ // committing the error page is treated as a single commit.
+ //
+ // The Link Doctor page will typically be one OnLoadCommitted with an error
+ // code, followed by another OnLoadCommitted with net::OK for the Link Doctor
+ // page.
+ virtual void OnLoadCommitted(int net_error);
+
+ // This is called when the current provisional load is canceled.
+ // Sets state to STATE_NONE, unless this is a login tab.
+ virtual void OnAbort();
+
+ // Called when the WebContents stops loading. Starts a captive portal check
+ // if this is the login tab.
+ virtual void OnStopLoading();
+
+ // Sets |state_| and takes any action associated with the new state.
+ void SetState(State new_state);
+
+ State state() const { return state_; }
+
+ // Used by unit tests.
+ void set_slow_ssl_load_time(base::TimeDelta slow_ssl_load_time) {
+ slow_ssl_load_time_ = slow_ssl_load_time;
+ }
+
+ // Started whenever an SSL tab starts loading, when the state is switched to
+ // STATE_TIMER_RUNNING. Stopped on any state change, including when a page
+ // commits or there's an error. If the timer triggers, the state switches to
+ // STATE_MAYBE_BROKEN_BY_PORTAL and |this| kicks off a captive portal check.
+ // TODO(mmenke): On redirects, update this timer.
+ base::OneShotTimer<CaptivePortalTabHelper> slow_ssl_load_timer_;
+
+ // Handles messages from the WebContents. Separate class to simplify logic
+ // and testing.
+ CaptivePortalTabObserver observer_;
+
+ private:
+ friend class CaptivePortalBrowserTest;
+ friend class CaptivePortalTabObserver;
+
+ // content::NotificationObserver:
+ virtual void Observe(
+ int type,
+ const content::NotificationSource& source,
+ const content::NotificationDetails& details) OVERRIDE;
+
+ // Called by a timer when an SSL main frame provisional load is taking a
+ // while to commit.
+ void OnSlowSSLConnect();
+
+ // Reloads the tab if there's no provisional load going on and the current
+ // state is STATE_NEEDS_RELOAD. Not safe to call synchronously when called
+ // by |observer_|, since the WebContents is already taking some action.
+ void ReloadTabIfNeeded();
+
+ // Reloads the tab.
+ virtual void ReloadTab();
+
+ // Opens a login tab in the topmost browser window for the |profile_|, if the
+ // profile has a tabbed browser window and the window doesn't already have a
+ // login tab. Otherwise, does nothing.
+ virtual void MaybeOpenCaptivePortalLoginTab();
+
+ // Tries to get |profile_|'s CaptivePortalService and have it start a captive
+ // portal check.
+ virtual void CheckForCaptivePortal();
+
+ Profile* profile_;
+
+ State state_;
+
+ // Tracks if there's a load going on that can't safely be interrupted. This
+ // is true between the time when a provisional load fails and when an error
+ // page's provisional load starts, so does not perfectly align with the
+ // notion of a provisional load used by the WebContents.
+ bool provisional_main_frame_load_;
+
+ // Time to wait after a provisional HTTPS load before triggering a captive
+ // portal check.
+ base::TimeDelta slow_ssl_load_time_;
+
+ base::WeakPtrFactory<CaptivePortalTabHelper> weak_factory_;
+
+ content::NotificationRegistrar registrar_;
+
+ DISALLOW_COPY_AND_ASSIGN(CaptivePortalTabHelper);
+};
+
+} // namespace captive_portal
+
+#endif // CHROME_BROWSER_CAPTIVE_PORTAL_CAPTIVE_PORTAL_TAB_HELPER_H_
Property changes on: chrome\browser\captive_portal\captive_portal_tab_helper.h
___________________________________________________________________
Added: svn:eol-style
+ LF
« no previous file with comments | « chrome/browser/captive_portal/captive_portal_service.h ('k') | chrome/browser/captive_portal/captive_portal_tab_helper.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698