OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/android/data_usage/data_use_tab_helper.h" | 5 #include "chrome/browser/android/data_usage/data_use_tab_helper.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "chrome/browser/android/data_usage/data_use_ui_tab_model.h" | 8 #include "chrome/browser/android/data_usage/data_use_ui_tab_model.h" |
9 #include "chrome/browser/android/data_usage/data_use_ui_tab_model_factory.h" | 9 #include "chrome/browser/android/data_usage/data_use_ui_tab_model_factory.h" |
10 #include "chrome/browser/profiles/profile.h" | 10 #include "chrome/browser/profiles/profile.h" |
11 #include "chrome/browser/sessions/session_tab_helper.h" | 11 #include "chrome/browser/sessions/session_tab_helper.h" |
| 12 #include "components/sessions/core/session_id.h" |
12 #include "content/public/browser/browser_thread.h" | 13 #include "content/public/browser/browser_thread.h" |
13 #include "content/public/browser/navigation_handle.h" | 14 #include "content/public/browser/navigation_handle.h" |
| 15 #include "content/public/browser/render_frame_host.h" |
14 #include "ui/base/page_transition_types.h" | 16 #include "ui/base/page_transition_types.h" |
15 | 17 |
16 namespace content { | |
17 class RenderFrameHost; | |
18 } | |
19 | |
20 DEFINE_WEB_CONTENTS_USER_DATA_KEY(DataUseTabHelper); | 18 DEFINE_WEB_CONTENTS_USER_DATA_KEY(DataUseTabHelper); |
21 | 19 |
22 DataUseTabHelper::~DataUseTabHelper() {} | 20 DataUseTabHelper::~DataUseTabHelper() {} |
23 | 21 |
24 DataUseTabHelper::DataUseTabHelper(content::WebContents* web_contents) | 22 DataUseTabHelper::DataUseTabHelper(content::WebContents* web_contents) |
25 : content::WebContentsObserver(web_contents) { | 23 : content::WebContentsObserver(web_contents) { |
26 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); | 24 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); |
27 } | 25 } |
28 | 26 |
29 void DataUseTabHelper::ReadyToCommitNavigation( | 27 void DataUseTabHelper::DidFinishNavigation( |
30 content::NavigationHandle* navigation_handle) { | 28 content::NavigationHandle* navigation_handle) { |
31 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); | 29 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); |
| 30 // TODO(tbansal): Consider the case of a page that provides a navigation bar |
| 31 // and loads pages in a sub-frame. |
| 32 if (!navigation_handle->IsInMainFrame()) |
| 33 return; |
32 | 34 |
33 // Notify the DataUseUITabModel. | 35 // Notify the DataUseUITabModel. |
34 chrome::android::DataUseUITabModel* data_use_ui_tab_model = | 36 chrome::android::DataUseUITabModel* data_use_ui_tab_model = |
35 chrome::android::DataUseUITabModelFactory::GetForBrowserContext( | 37 chrome::android::DataUseUITabModelFactory::GetForBrowserContext( |
36 Profile::FromBrowserContext(web_contents()->GetBrowserContext())); | 38 Profile::FromBrowserContext(web_contents()->GetBrowserContext())); |
37 if (data_use_ui_tab_model) { | 39 SessionID::id_type tab_id = SessionTabHelper::IdForTab(web_contents()); |
| 40 if (data_use_ui_tab_model && tab_id >= 0) { |
38 data_use_ui_tab_model->ReportBrowserNavigation( | 41 data_use_ui_tab_model->ReportBrowserNavigation( |
39 navigation_handle->GetURL(), | 42 navigation_handle->GetURL(), |
40 ui::PageTransitionFromInt(navigation_handle->GetPageTransition()), | 43 ui::PageTransitionFromInt(navigation_handle->GetPageTransition()), |
41 SessionTabHelper::IdForTab(web_contents())); | 44 tab_id); |
42 } | 45 } |
43 } | 46 } |
44 | 47 |
45 void DataUseTabHelper::FrameDeleted( | 48 void DataUseTabHelper::RenderFrameDeleted( |
46 content::RenderFrameHost* render_frame_host) { | 49 content::RenderFrameHost* render_frame_host) { |
47 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); | 50 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); |
48 | 51 |
| 52 // Check if it is a main frame. |
| 53 if (render_frame_host->GetParent()) |
| 54 return; |
| 55 |
49 // Notify the DataUseUITabModel. | 56 // Notify the DataUseUITabModel. |
50 chrome::android::DataUseUITabModel* data_use_ui_tab_model = | 57 chrome::android::DataUseUITabModel* data_use_ui_tab_model = |
51 chrome::android::DataUseUITabModelFactory::GetForBrowserContext( | 58 chrome::android::DataUseUITabModelFactory::GetForBrowserContext( |
52 Profile::FromBrowserContext(web_contents()->GetBrowserContext())); | 59 Profile::FromBrowserContext(web_contents()->GetBrowserContext())); |
53 if (data_use_ui_tab_model) { | 60 SessionID::id_type tab_id = SessionTabHelper::IdForTab(web_contents()); |
54 data_use_ui_tab_model->ReportTabClosure( | 61 if (data_use_ui_tab_model && tab_id >= 0) |
55 SessionTabHelper::IdForTab(web_contents())); | 62 data_use_ui_tab_model->ReportTabClosure(tab_id); |
56 } | |
57 } | 63 } |
OLD | NEW |