This source file includes following definitions.
- GetGroupIndex
- MonitoredDomainGroupId
- LogUMAHistogramEnumeration
- LogUMAHistogramBoolean
- GroupIdToString
#include "components/password_manager/core/browser/password_manager_metrics_util.h"
#include "base/basictypes.h"
#include "base/metrics/histogram.h"
#include "base/numerics/safe_conversions.h"
#include "base/prefs/pref_service.h"
#include "base/prefs/scoped_user_pref_update.h"
#include "base/rand_util.h"
#include "base/strings/string_number_conversions.h"
#include "base/strings/string_util.h"
#include "base/time/time.h"
#include "base/values.h"
#include "components/password_manager/core/common/password_manager_pref_names.h"
#include "url/gurl.h"
using base::ListValue;
using base::FundamentalValue;
namespace password_manager_metrics_util {
namespace {
const size_t kNumGroups = 2u * kGroupsPerDomain;
struct DomainGroupsPair {
const char* const domain_name;
const size_t group_ids[kGroupsPerDomain];
};
const DomainGroupsPair kDomainMapping[] = {
{"google.com", {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}},
{"yahoo.com", {1, 2, 3, 4, 5, 11, 12, 13, 14, 15}},
{"baidu.com", {1, 2, 3, 4, 6, 7, 11, 12, 16, 17}},
{"wikipedia.org", {1, 2, 3, 4, 5, 6, 11, 12, 16, 18}},
{"linkedin.com", {1, 6, 8, 11, 13, 14, 15, 16, 17, 19}},
{"twitter.com", {5, 6, 7, 8, 9, 11, 13, 17, 19, 20}},
{"facebook.com", {7, 8, 9, 10, 13, 14, 16, 17, 18, 20}},
{"amazon.com", {2, 5, 9, 10, 12, 14, 15, 18, 19, 20}},
{"ebay.com", {3, 7, 9, 10, 14, 15, 17, 18, 19, 20}},
{"tumblr.com", {4, 8, 10, 12, 13, 15, 16, 18, 19, 20}},
};
const size_t kNumDomains = arraysize(kDomainMapping);
size_t GetGroupIndex(size_t domain_index, PrefService* pref_service) {
DCHECK_LT(domain_index, kNumDomains);
const base::ListValue* group_indices =
pref_service->GetList(prefs::kPasswordManagerGroupsForDomains);
int result = 0;
if (!group_indices->GetInteger(domain_index, &result)) {
ListPrefUpdate group_indices_updater(
pref_service, prefs::kPasswordManagerGroupsForDomains);
result =
base::checked_cast<int>(base::RandGenerator(kGroupsPerDomain));
group_indices_updater->Set(domain_index, new FundamentalValue(result));
}
return base::checked_cast<size_t>(result);
}
}
size_t MonitoredDomainGroupId(const std::string& url_host,
PrefService* pref_service) {
GURL url(url_host);
for (size_t i = 0; i < kNumDomains; ++i) {
if (url.DomainIs(kDomainMapping[i].domain_name))
return kDomainMapping[i].group_ids[GetGroupIndex(i, pref_service)];
}
return 0;
}
void LogUMAHistogramEnumeration(const std::string& name,
int sample,
int boundary_value) {
DCHECK_LT(sample, boundary_value);
base::HistogramBase* histogram =
base::LinearHistogram::FactoryGet(
name,
1,
boundary_value,
boundary_value + 1,
base::HistogramBase::kUmaTargetedHistogramFlag);
histogram->Add(sample);
}
void LogUMAHistogramBoolean(const std::string& name, bool sample) {
base::HistogramBase* histogram =
base::BooleanHistogram::FactoryGet(
name,
base::Histogram::kNoFlags);
histogram->AddBoolean(sample);
}
std::string GroupIdToString(size_t group_id) {
DCHECK_LE(group_id, kNumGroups);
if (group_id > 0)
return "group_" + base::IntToString(group_id);
return std::string();
}
}