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

Unified Diff: chrome/installer/util/beacons.h

Issue 1146843003: Beacons for tracking default browser status. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: revise active setup version Created 5 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/installer/util/beacons.h
diff --git a/chrome/installer/util/beacons.h b/chrome/installer/util/beacons.h
new file mode 100644
index 0000000000000000000000000000000000000000..2ff0450644f7c224bc48cb60019a50107b3a3caf
--- /dev/null
+++ b/chrome/installer/util/beacons.h
@@ -0,0 +1,119 @@
+// Copyright 2015 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.
+
+#ifndef CHROME_INSTALLER_UTIL_BEACONS_H_
+#define CHROME_INSTALLER_UTIL_BEACONS_H_
+
+#include <windows.h>
+
+#include "base/macros.h"
+#include "base/memory/scoped_ptr.h"
+#include "base/strings/string16.h"
+#include "base/strings/string_piece.h"
+#include "base/time/time.h"
+#include "chrome/installer/util/shell_util.h"
+
+class AppRegistrationData;
+class BrowserDistribution;
+
+namespace base {
+class FilePath;
+}
+
+// Checks the default state of the browser for the current user and updates the
+// appropriate beacon (last was default or first not default).
gab 2015/05/26 18:54:34 Reorder sentence to begin with the actual action t
grt (UTC plus 2) 2015/05/26 20:54:01 It is in the right order: it checks the default st
gab 2015/05/29 13:37:36 Well the fact that it "checks" is a side-effect of
grt (UTC plus 2) 2015/05/29 15:31:10 The only way that the beacons can be updated to re
+void UpdateDefaultBrowserBeaconForPath(const base::FilePath& chrome_exe);
+
+// Updates the last was default or first not default beacon for the current user
+// based on |default_state|.
+void UpdateDefaultBrowserBeacon(const base::FilePath& chrome_exe,
gab 2015/05/26 18:54:34 s/UpdateDefaultBrowserBeacon/UpdateDefaultBrowserB
grt (UTC plus 2) 2015/05/26 20:54:01 Done.
+ BrowserDistribution* distribution,
+ ShellUtil::DefaultState default_state);
+
+// Updates the last OS upgrade beacon for the install.
+void UpdateOsUpgradeBeacon(bool system_install,
+ BrowserDistribution* distribution);
+
+// A named beacon stored in the registry representing the first or last time at
+// which some event took place. A beacon may apply to a per-user event or a
+// per-install event.
+class Beacon {
gab 2015/05/26 18:54:34 I think this should either be in the install_util
grt (UTC plus 2) 2015/05/26 20:54:01 I've been steered away from namespaces by other re
grt (UTC plus 2) 2015/05/28 14:05:42 Thinking about it more, this class is pretty much
gab 2015/05/29 13:37:36 I like a namespace here; otherwise you need a more
grt (UTC plus 2) 2015/05/29 15:31:10 Done.
+ public:
+ ~Beacon();
gab 2015/05/26 18:54:34 I think you can use ~Beacon() = default; here inst
grt (UTC plus 2) 2015/05/26 20:54:01 A string16 isn't a POD since it has a dtor, but ma
+
+ // Returns an instance representing the last time the machine's OS was
+ // ugpraded.
+ static scoped_ptr<Beacon> LastOsUpgrade(
+ bool system_install,
+ const AppRegistrationData& registration_data);
+
+ // Returns an instance representing the last time Chrome was the user's
+ // default browser.
+ static scoped_ptr<Beacon> LastWasDefault(
+ bool system_install,
+ const AppRegistrationData& registration_data);
+
+ // Returns an instance representing the first time Chrome was not the user's
+ // default browser.
+ static scoped_ptr<Beacon> FirstNotDefault(
+ bool system_install,
+ const AppRegistrationData& registration_data);
+
+ // Updates the beacon. For a type LAST beacon, the current time is written
+ // unconditionally. For a type FIRST beacon, the beacon is only updated if it
+ // does not already exist.
+ void Update();
+
+ // Removes the beacon.
+ void Remove();
+
+ // Returns the beacon's value or a null time if not found.
+ base::Time Get();
+
+ protected:
+ enum class BeaconType {
+ // A beacon that marks the first occurrence of an event.
+ FIRST,
+ // A beacon that marks the last occurrence of an event.
+ LAST,
+ };
+
+ enum class BeaconScope {
+ // A beacon that applies to a per-user event.
+ PER_USER,
+ // A beacon that applies to a per-install event.
+ PER_INSTALL,
+ };
+
+ Beacon(base::StringPiece16 name,
+ BeaconType type,
+ BeaconScope scope,
+ bool system_install,
+ const AppRegistrationData& registration_data);
+
+ private:
+ // Initializes the key_path_ and value_name_ fields of the beacon.
+ void Initialize(base::StringPiece16 name,
+ bool system_install,
+ const AppRegistrationData& registration_data);
+
+ // The type of beacon.
+ const BeaconType type_;
+
+ // The root key in the registry where this beacon is stored.
+ const HKEY root_;
+
+ // The scope of the beacon.
+ const BeaconScope scope_;
+
+ // The path to the registry key holding the beacon.
+ base::string16 key_path_;
+
+ // The name of the registry value holding the beacon.
+ base::string16 value_name_;
+
+ DISALLOW_COPY_AND_ASSIGN(Beacon);
+};
+
+#endif // CHROME_INSTALLER_UTIL_BEACONS_H_

Powered by Google App Engine
This is Rietveld 408576698