Chromium Code Reviews| 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 |