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

Unified Diff: chrome/browser/metrics/extensions_metrics_provider.h

Issue 297483008: Refactor HashedExtensionMetrics into ExtensionsMetricsProvider. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase Created 6 years, 7 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/metrics/extensions_metrics_provider.h
diff --git a/chrome/browser/metrics/extension_metrics.h b/chrome/browser/metrics/extensions_metrics_provider.h
similarity index 60%
rename from chrome/browser/metrics/extension_metrics.h
rename to chrome/browser/metrics/extensions_metrics_provider.h
index bf086d23e04d78689219952f66990091cdbdaa5e..6cca94dc30a5da87b50815a8fe7f554538573297 100644
--- a/chrome/browser/metrics/extension_metrics.h
+++ b/chrome/browser/metrics/extensions_metrics_provider.h
@@ -2,13 +2,14 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#ifndef CHROME_BROWSER_METRICS_EXTENSION_METRICS_H_
-#define CHROME_BROWSER_METRICS_EXTENSION_METRICS_H_
+#ifndef CHROME_BROWSER_METRICS_EXTENSIONS_METRICS_PROVIDER_H_
+#define CHROME_BROWSER_METRICS_EXTENSIONS_METRICS_PROVIDER_H_
#include <string>
#include "base/basictypes.h"
#include "base/memory/scoped_ptr.h"
+#include "components/metrics/metrics_provider.h"
class Profile;
@@ -17,31 +18,40 @@ class ExtensionSet;
}
namespace metrics {
+class MetricsStateManager;
class SystemProfileProto;
}
-// HashedExtensionMetrics groups various constants and functions used for
+// ExtensionsMetricsProvider groups various constants and functions used for
// reporting extension IDs with UMA reports (after hashing the extension IDs
// for privacy).
-class HashedExtensionMetrics {
+class ExtensionsMetricsProvider : public metrics::MetricsProvider {
public:
- explicit HashedExtensionMetrics(uint64 client_id);
- virtual ~HashedExtensionMetrics();
+ // Holds on to |metrics_state_manager|, which must outlive this object, as a
+ // weak pointer.
+ explicit ExtensionsMetricsProvider(
+ metrics::MetricsStateManager* metrics_state_manager);
+ virtual ~ExtensionsMetricsProvider();
+
+ // metrics::MetricsProvider:
// Writes the hashed list of installed extensions into the specified
// SystemProfileProto object.
- void WriteExtensionList(metrics::SystemProfileProto* system_profile);
+ virtual void ProvideSystemProfileMetrics(
+ metrics::SystemProfileProto* system_profile) OVERRIDE;
protected:
- // Retrieves the set of extensions installed in the current profile. The
- // default implementation should be fine, but this can be overridden for
- // testing.
- //
+ // Exposed for the sake of mocking in test code.
+
+ // Retrieves the set of extensions installed in the current profile.
// TODO(mvrable): If metrics are ever converted to being per-profile, then
// this should be updated to return extensions installed in a specified
// profile.
virtual scoped_ptr<extensions::ExtensionSet> GetInstalledExtensions();
+ // Retrieves the client ID.
+ virtual uint64 GetClientID();
+
// Hashes the extension extension ID using the provided client key (which
// must be less than kExtensionListClientKeys) and to produce an output value
// between 0 and kExtensionListBuckets-1.
@@ -53,15 +63,15 @@ class HashedExtensionMetrics {
// same value so that reported extensions are consistent.
Profile* GetMetricsProfile();
- // The key used when hashing extension identifiers, derived from client_id.
- const int client_key_;
+ // The MetricsStateManager from which the client ID is obtained.
+ metrics::MetricsStateManager* metrics_state_manager_;
// The profile for which extensions are gathered. Once a profile is found
// its value is cached here so that GetMetricsProfile() can return a
// consistent value.
Profile* cached_profile_;
- DISALLOW_COPY_AND_ASSIGN(HashedExtensionMetrics);
+ DISALLOW_COPY_AND_ASSIGN(ExtensionsMetricsProvider);
};
-#endif // CHROME_BROWSER_METRICS_EXTENSION_METRICS_H_
+#endif // CHROME_BROWSER_METRICS_EXTENSIONS_METRICS_PROVIDER_H_
« no previous file with comments | « chrome/browser/metrics/extension_metrics_unittest.cc ('k') | chrome/browser/metrics/extensions_metrics_provider.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698