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

Unified Diff: chrome/browser/interstitials/security_interstitial_uma_helper.cc

Issue 872813003: Add Rappor metrics for Safe Browsing and SSL interstitials. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 11 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/interstitials/security_interstitial_uma_helper.cc
diff --git a/chrome/browser/interstitials/security_interstitial_uma_helper.cc b/chrome/browser/interstitials/security_interstitial_uma_helper.cc
index aade7ff796f99560eac7d2bc1e126bfab6720f75..cba936fd41db970578209d34fd04bd9e2e3fdf06 100644
--- a/chrome/browser/interstitials/security_interstitial_uma_helper.cc
+++ b/chrome/browser/interstitials/security_interstitial_uma_helper.cc
@@ -2,14 +2,20 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
+
#include "chrome/browser/interstitials/security_interstitial_uma_helper.h"
+#include <string>
+
#include "base/metrics/histogram.h"
+#include "chrome/browser/browser_process.h"
#include "chrome/browser/history/history_service.h"
#include "chrome/browser/history/history_service_factory.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/webdata/web_data_service_factory.h"
+#include "components/rappor/rappor_service.h"
#include "content/public/browser/web_contents.h"
+#include "net/base/registry_controlled_domains/registry_controlled_domain.h"
#if defined(ENABLE_EXTENSIONS)
#include "chrome/browser/extensions/api/experience_sampling_private/experience_sampling.h"
@@ -18,11 +24,13 @@
SecurityInterstitialUmaHelper::SecurityInterstitialUmaHelper(
content::WebContents* web_contents,
const GURL& request_url,
- const std::string& histogram_prefix,
+ const std::string& uma_prefix,
+ const std::string& rappor_prefix,
const std::string& sampling_event_name)
: web_contents_(web_contents),
request_url_(request_url),
- histogram_prefix_(histogram_prefix),
+ uma_prefix_(uma_prefix),
+ rappor_prefix_(rappor_prefix),
sampling_event_name_(sampling_event_name),
num_visits_(-1) {
HistoryService* history_service = HistoryServiceFactory::GetForProfile(
@@ -40,18 +48,38 @@ SecurityInterstitialUmaHelper::SecurityInterstitialUmaHelper(
SecurityInterstitialUmaHelper::~SecurityInterstitialUmaHelper() {
}
-// Directly adds to the histograms, using the same properties as
+// Directly adds to the UMA histograms, using the same properties as
// UMA_HISTOGRAM_ENUMERATION, because the macro doesn't allow non-constant
-// histogram names.
+// histogram names. Reports to Rappor for certain decisions.
void SecurityInterstitialUmaHelper::RecordUserDecision(
SecurityInterstitialDecision decision) {
+ // UMA
std::string decision_histogram_name(
- "interstitial." + histogram_prefix_ + ".decision");
+ "interstitial." + uma_prefix_ + ".decision");
base::HistogramBase* decision_histogram = base::LinearHistogram::FactoryGet(
decision_histogram_name, 1, MAX_DECISION, MAX_DECISION + 1,
base::HistogramBase::kUmaTargetedHistogramFlag);
decision_histogram->Add(decision);
+ // Rappor
+ rappor::RapporService* rappor_service = g_browser_process->rappor_service();
+ if (rappor_service && !rappor_prefix_.empty()) {
+ if (decision == SHOW) {
felt 2015/01/28 19:19:17 nit: can you make this a single if-statement until
Nathan Parker 2015/01/29 01:36:02 Done.
+ const std::string domain =
+ net::registry_controlled_domains::GetDomainAndRegistry(
+ request_url_,
+ net::registry_controlled_domains::INCLUDE_PRIVATE_REGISTRIES);
+
+ // e.g. "Interstitial.Malware.Domain"
+ const std::string metric_name =
+ "Interstitial." + rappor_prefix_ + ".Domain";
felt 2015/01/28 19:19:17 Do we really need to have both uma_prefix and rapp
Nathan Parker 2015/01/29 01:36:02 Unfortunately they have different capitalization.
Steven Holte 2015/01/29 02:46:12 I would lean towards being consistent with the rel
Nathan Parker 2015/01/30 00:39:51 In that case I'll user lowercase for both. I'll u
+ rappor_service->RecordSample(metric_name, rappor::COARSE_RAPPOR_TYPE,
+ domain);
+ }
+ // TODO(nparker): Add Rappor reporting at PROCEED and DONT_PROCEED once
+ // crbug.com/451647 is fixed.
+ }
+
#if defined(ENABLE_EXTENSIONS)
if (!sampling_event_.get()) {
sampling_event_.reset(new extensions::ExperienceSamplingEvent(
@@ -81,7 +109,7 @@ void SecurityInterstitialUmaHelper::RecordUserDecision(
if (num_visits_ < 1 || (decision != PROCEED && decision != DONT_PROCEED))
return;
std::string history_histogram_name(
- "interstitial." + histogram_prefix_ + ".decision.repeat_visit");
+ "interstitial." + uma_prefix_ + ".decision.repeat_visit");
base::HistogramBase* history_histogram = base::LinearHistogram::FactoryGet(
history_histogram_name, 1, MAX_DECISION, MAX_DECISION + 1,
base::HistogramBase::kUmaTargetedHistogramFlag);
@@ -92,7 +120,7 @@ void SecurityInterstitialUmaHelper::RecordUserDecision(
void SecurityInterstitialUmaHelper::RecordUserInteraction(
SecurityInterstitialInteraction interaction) {
std::string interaction_histogram_name(
- "interstitial." + histogram_prefix_ + ".interaction");
+ "interstitial." + uma_prefix_ + ".interaction");
base::HistogramBase* interaction_histogram =
base::LinearHistogram::FactoryGet(
interaction_histogram_name, 1, MAX_INTERACTION, MAX_INTERACTION + 1,

Powered by Google App Engine
This is Rietveld 408576698