• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #ifndef CHROME_BROWSER_NET_NET_ERROR_TAB_HELPER_H_
6 #define CHROME_BROWSER_NET_NET_ERROR_TAB_HELPER_H_
7 
8 #include "base/basictypes.h"
9 #include "base/bind.h"
10 #include "base/compiler_specific.h"
11 #include "base/memory/weak_ptr.h"
12 #include "base/prefs/pref_member.h"
13 #include "chrome/browser/net/dns_probe_service.h"
14 #include "chrome/common/net/net_error_info.h"
15 #include "content/public/browser/web_contents_observer.h"
16 #include "content/public/browser/web_contents_user_data.h"
17 
18 namespace chrome_browser_net {
19 
20 // A TabHelper that monitors loads for certain types of network errors and
21 // does interesting things with them.  Currently, starts DNS probes using the
22 // DnsProbeService whenever a page fails to load with a DNS-related error.
23 class NetErrorTabHelper
24     : public content::WebContentsObserver,
25       public content::WebContentsUserData<NetErrorTabHelper> {
26  public:
27   enum TestingState {
28     TESTING_DEFAULT,
29     TESTING_FORCE_DISABLED,
30     TESTING_FORCE_ENABLED
31   };
32 
33   typedef base::Callback<void(chrome_common_net::DnsProbeStatus)>
34       DnsProbeStatusSnoopCallback;
35 
36   virtual ~NetErrorTabHelper();
37 
38   static void set_state_for_testing(TestingState testing_state);
39 
40   // Sets a callback that will be called immediately after the helper sends
41   // a NetErrorHelper IPC.  (Used by the DNS probe browser test to know when to
42   // check the error page for updates, instead of polling.)
set_dns_probe_status_snoop_callback_for_testing(const DnsProbeStatusSnoopCallback & dns_probe_status_snoop_callback)43   void set_dns_probe_status_snoop_callback_for_testing(
44       const DnsProbeStatusSnoopCallback& dns_probe_status_snoop_callback) {
45     dns_probe_status_snoop_callback_ = dns_probe_status_snoop_callback;
46   }
47 
48   // content::WebContentsObserver implementation.
49   virtual void DidStartProvisionalLoadForFrame(
50       int64 frame_id,
51       int64 parent_frame_id,
52       bool is_main_frame,
53       const GURL& validated_url,
54       bool is_error_page,
55       bool is_iframe_srcdoc,
56       content::RenderViewHost* render_view_host) OVERRIDE;
57 
58   virtual void DidCommitProvisionalLoadForFrame(
59       int64 frame_id,
60       const base::string16& frame_unique_name,
61       bool is_main_frame,
62       const GURL& url,
63       content::PageTransition transition_type,
64       content::RenderViewHost* render_view_host) OVERRIDE;
65 
66   virtual void DidFailProvisionalLoad(
67       int64 frame_id,
68       const base::string16& frame_unique_name,
69       bool is_main_frame,
70       const GURL& validated_url,
71       int error_code,
72       const base::string16& error_description,
73       content::RenderViewHost* render_view_host) OVERRIDE;
74 
75  protected:
76   // |contents| is the WebContents of the tab this NetErrorTabHelper is
77   // attached to.
78   explicit NetErrorTabHelper(content::WebContents* contents);
79   virtual void StartDnsProbe();
80   virtual void SendInfo();
81   void OnDnsProbeFinished(chrome_common_net::DnsProbeStatus result);
82 
dns_probe_status()83   chrome_common_net::DnsProbeStatus dns_probe_status() const {
84     return dns_probe_status_;
85   }
86 
87  private:
88   friend class content::WebContentsUserData<NetErrorTabHelper>;
89 
90   void OnMainFrameDnsError();
91 
92   void InitializePref(content::WebContents* contents);
93   bool ProbesAllowed() const;
94 
95   base::WeakPtrFactory<NetErrorTabHelper> weak_factory_;
96 
97   // True if the last provisional load that started was for an error page.
98   bool is_error_page_;
99 
100   // True if the helper has seen a main frame page load fail with a DNS error,
101   // but has not yet seen a new page commit successfully afterwards.
102   bool dns_error_active_;
103 
104   // True if the helper has seen an error page commit while |dns_error_active_|
105   // is true.  (This should never be true if |dns_error_active_| is false.)
106   bool dns_error_page_committed_;
107 
108   // The status of a DNS probe that may or may not have started or finished.
109   // Since the renderer can change out from under the helper (in cross-process
110   // navigations), it re-sends the status whenever an error page commits.
111   chrome_common_net::DnsProbeStatus dns_probe_status_;
112 
113   // Optional callback for browser test to snoop on outgoing NetErrorInfo IPCs.
114   DnsProbeStatusSnoopCallback dns_probe_status_snoop_callback_;
115 
116   // "Use a web service to resolve navigation errors" preference is required
117   // to allow probes.
118   BooleanPrefMember resolve_errors_with_web_service_;
119 
120   DISALLOW_COPY_AND_ASSIGN(NetErrorTabHelper);
121 };
122 
123 }  // namespace chrome_browser_net
124 
125 #endif  // CHROME_BROWSER_NET_NET_ERROR_TAB_HELPER_H_
126