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

Unified Diff: chrome/browser/data_use_measurement/chrome_data_use_ascriber_service.cc

Issue 2285903002: Framework to ascribe all network data use to a source. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressed nits Created 4 years, 3 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/data_use_measurement/chrome_data_use_ascriber_service.cc
diff --git a/chrome/browser/data_use_measurement/chrome_data_use_ascriber_service.cc b/chrome/browser/data_use_measurement/chrome_data_use_ascriber_service.cc
new file mode 100644
index 0000000000000000000000000000000000000000..7e01b59a2d29d56a9395f2f893972a0f246fc63e
--- /dev/null
+++ b/chrome/browser/data_use_measurement/chrome_data_use_ascriber_service.cc
@@ -0,0 +1,160 @@
+// Copyright 2016 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.
+
+#include "chrome/browser/data_use_measurement/chrome_data_use_ascriber_service.h"
+
+#include "base/bind.h"
+#include "base/memory/ptr_util.h"
+#include "chrome/browser/browser_process.h"
+#include "chrome/browser/data_use_measurement/chrome_data_use_ascriber.h"
+#include "chrome/browser/io_thread.h"
+#include "content/public/browser/browser_thread.h"
+#include "content/public/browser/navigation_handle.h"
+#include "content/public/browser/render_frame_host.h"
+#include "content/public/browser/render_process_host.h"
+#include "content/public/browser/web_contents.h"
+
+namespace {
+
+data_use_measurement::ChromeDataUseAscriber* InitOnIOThread(
+ IOThread* io_thread) {
+ DCHECK(io_thread);
+ DCHECK_CURRENTLY_ON(content::BrowserThread::IO);
+
+ return io_thread->globals()->data_use_ascriber.get();
+}
+
+} // namespace
+
+namespace data_use_measurement {
+
+ChromeDataUseAscriberService::ChromeDataUseAscriberService()
+ : ascriber_(nullptr) {
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
+
+ // Skip IO thread initialization if there is no IO thread. This check is
+ // required because unit tests that do no set up an IO thread can cause this
+ // code to execute.
+ if (!g_browser_process->io_thread())
+ return;
+
+ content::BrowserThread::PostTaskAndReplyWithResult(
+ content::BrowserThread::IO, FROM_HERE,
+ base::Bind(&InitOnIOThread, g_browser_process->io_thread()),
+ base::Bind(&ChromeDataUseAscriberService::SetDataUseAscriber,
+ base::Unretained(this)));
+}
+
+ChromeDataUseAscriberService::~ChromeDataUseAscriberService() {
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
+}
+
+void ChromeDataUseAscriberService::RenderFrameCreated(
+ content::RenderFrameHost* render_frame_host) {
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
+
+ if (!ascriber_)
+ return;
+
+ int parent_render_process_id = -1;
+ int parent_render_frame_id = -1;
+ if (render_frame_host->GetParent()) {
+ parent_render_process_id =
+ render_frame_host->GetParent()->GetProcess()->GetID();
+ parent_render_frame_id = render_frame_host->GetParent()->GetRoutingID();
+ }
+ content::BrowserThread::PostTask(
+ content::BrowserThread::IO, FROM_HERE,
+ base::Bind(&ChromeDataUseAscriber::RenderFrameCreated,
+ base::Unretained(ascriber_),
+ render_frame_host->GetProcess()->GetID(),
+ render_frame_host->GetRoutingID(), parent_render_process_id,
+ parent_render_frame_id));
+}
+
+void ChromeDataUseAscriberService::RenderFrameDeleted(
+ content::RenderFrameHost* render_frame_host) {
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
+
+ if (!ascriber_)
+ return;
+
+ int parent_render_frame_id = -1;
+ int parent_render_process_id = -1;
+
+ if (render_frame_host->GetParent()) {
+ parent_render_process_id =
+ render_frame_host->GetParent()->GetProcess()->GetID();
+ parent_render_frame_id = render_frame_host->GetParent()->GetRoutingID();
+ }
+ content::BrowserThread::PostTask(
+ content::BrowserThread::IO, FROM_HERE,
+ base::Bind(&ChromeDataUseAscriber::RenderFrameDeleted,
+ base::Unretained(ascriber_),
+ render_frame_host->GetProcess()->GetID(),
+ render_frame_host->GetRoutingID(), parent_render_process_id,
+ parent_render_frame_id));
+}
+
+void ChromeDataUseAscriberService::DidStartNavigation(
+ content::NavigationHandle* navigation_handle) {
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
+
+ if (!ascriber_ || !navigation_handle->IsInMainFrame())
+ return;
+
+ content::WebContents* web_contents = navigation_handle->GetWebContents();
+ content::BrowserThread::PostTask(
+ content::BrowserThread::IO, FROM_HERE,
+ base::Bind(&ChromeDataUseAscriber::DidStartMainFrameNavigation,
+ base::Unretained(ascriber_), navigation_handle->GetURL(),
+ web_contents->GetRenderProcessHost()->GetID(),
+ web_contents->GetMainFrame()->GetRoutingID(),
+ navigation_handle));
+}
+
+void ChromeDataUseAscriberService::DidFinishNavigation(
+ content::NavigationHandle* navigation_handle) {
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
+
+ if (!ascriber_ || !navigation_handle->IsInMainFrame())
+ return;
+
+ content::WebContents* web_contents = navigation_handle->GetWebContents();
+ content::BrowserThread::PostTask(
+ content::BrowserThread::IO, FROM_HERE,
+ base::Bind(
+ &ChromeDataUseAscriber::DidFinishMainFrameNavigation,
+ base::Unretained(ascriber_), navigation_handle->GetURL(),
+ web_contents->GetRenderProcessHost()->GetID(),
+ web_contents->GetMainFrame()->GetRoutingID(),
+ !navigation_handle->HasCommitted() || navigation_handle->IsSamePage(),
+ navigation_handle));
+}
+
+void ChromeDataUseAscriberService::DidRedirectNavigation(
+ content::NavigationHandle* navigation_handle) {
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
+
+ if (!ascriber_ || !navigation_handle->IsInMainFrame())
+ return;
+
+ content::WebContents* web_contents = navigation_handle->GetWebContents();
+ content::BrowserThread::PostTask(
+ content::BrowserThread::IO, FROM_HERE,
+ base::Bind(&ChromeDataUseAscriber::DidRedirectMainFrameNavigation,
+ base::Unretained(ascriber_), navigation_handle->GetURL(),
+ web_contents->GetRenderProcessHost()->GetID(),
+ web_contents->GetMainFrame()->GetRoutingID(),
+ navigation_handle));
+}
+
+void ChromeDataUseAscriberService::SetDataUseAscriber(
+ ChromeDataUseAscriber* ascriber) {
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
+
+ ascriber_ = ascriber;
+}
+
+} // namespace data_use_measurement

Powered by Google App Engine
This is Rietveld 408576698