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

Unified Diff: chrome/installer/util/eula_util.cc

Issue 12035043: Implementing app command to query EULA acceptance state for Chrome. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Now using setup.exe; removing all Browser and App Launcher changes. Created 7 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/installer/util/eula_util.cc
diff --git a/chrome/installer/util/eula_util.cc b/chrome/installer/util/eula_util.cc
new file mode 100755
index 0000000000000000000000000000000000000000..1f34959ba54dcd6237a40f7532687f95b66a9835
--- /dev/null
+++ b/chrome/installer/util/eula_util.cc
@@ -0,0 +1,98 @@
+// Copyright (c) 2013 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/installer/util/eula_util.h"
+
+#include <windows.h>
+
+#include "base/file_util.h"
+#include "chrome/common/chrome_constants.h"
+#include "chrome/installer/launcher_support/chrome_launcher_support.h"
+#include "chrome/installer/util/browser_distribution.h"
+#include "chrome/installer/util/install_util.h"
+#include "chrome/installer/util/installation_state.h"
+#include "chrome/installer/util/master_preferences.h"
+#include "chrome/installer/util/master_preferences_constants.h"
+#include "chrome/installer/util/util_constants.h"
+
+namespace installer {
+
+namespace {
+
+bool IsChromeFirstRun(BrowserDistribution* dist) {
grt (UTC plus 2) 2013/01/24 02:51:40 IsChromeFirstRun -> IsChromeFirstRunPending or som
huangs 2013/01/24 18:56:03 Done.
+ // If there is problem getting sentinel path, assume not first run.
grt (UTC plus 2) 2013/01/24 02:51:40 If there is a problem getting the sentinel path, a
huangs 2013/01/24 18:56:03 Done (rephrased to fit line).
+ FilePath first_run_sentinel;
+ return InstallUtil::GetSentinelFilePath(chrome::kFirstRunSentinel,
+ dist,
+ &first_run_sentinel)
+ && !file_util::PathExists(first_run_sentinel);
+}
+
+bool IsEULASentinelPresent(BrowserDistribution* dist ) {
grt (UTC plus 2) 2013/01/24 02:51:40 "dist " -> "dist"
huangs 2013/01/24 18:56:03 Done.
+ // If there is problem getting sentinel path, assume EULA not accepted.
+ FilePath eula_sentinel;
+ return InstallUtil::GetSentinelFilePath(kEULASentinelFile,
+ dist,
+ &eula_sentinel)
+ && file_util::PathExists(eula_sentinel);
+}
+
+MasterPreferences* GetNewMasterPrefs() {
grt (UTC plus 2) 2013/01/24 02:51:40 scoped_ptr<MasterPreferences> GetNewMasterPrefs()
huangs 2013/01/24 18:56:03 Done.
+ // The standard location of the master prefs is next to the chrome binary.
+ FilePath chrome_exe(chrome_launcher_support::GetAnyChromePath());
grt (UTC plus 2) 2013/01/24 02:51:40 i haven't read what GetAnyChromePath does, but wha
huangs 2013/01/24 18:56:03 Done (need to pass const ProductState& product_sta
+ if (!chrome_exe.empty()) {
+ FilePath master_prefs_path(chrome_exe.DirName());
+ MasterPreferences* install_prefs = new MasterPreferences(
grt (UTC plus 2) 2013/01/24 02:51:40 scoped_ptr<MasterPreferences> install_prefs(...);
huangs 2013/01/24 18:56:03 Done.
+ master_prefs_path.AppendASCII(kDefaultMasterPrefs));
+ if (install_prefs != NULL) {
grt (UTC plus 2) 2013/01/24 02:51:40 if (install_prefs && install_prefs->read_from_file
huangs 2013/01/24 18:56:03 Done.
+ if (install_prefs->read_from_file())
+ return install_prefs;
+
+ delete install_prefs;
+ }
+ }
+ return NULL;
grt (UTC plus 2) 2013/01/24 02:51:40 you may need to make this: return scoped_ptr<Mas
huangs 2013/01/24 18:56:03 Done. Thanks!
+}
+
+bool IsEULARequiredInMasterPrefs(MasterPreferences* install_prefs) {
grt (UTC plus 2) 2013/01/24 02:51:40 this function takes a MasterPreferences, so it doe
huangs 2013/01/24 18:56:03 The function is added because I was envisioning re
+ bool val = false;
+ // If kRequireEula value is absent, assume EULA is not required.
+ if (!install_prefs->GetBool(master_preferences::kRequireEula, &val))
+ return false;
+
+ return val;
+}
+
+} // namespace
+
+HRESULT IsEULAAccepted() {
+ BrowserDistribution* dist = BrowserDistribution::GetSpecificDistribution(
+ BrowserDistribution::CHROME_BINARIES);
+ if (!dist)
+ return E_FAIL; // Error: system-level binaries aren't installed.
grt (UTC plus 2) 2013/01/24 02:51:40 !dist means that the impossible happened rather th
huangs 2013/01/24 18:56:03 Done.
+
+ ProductState binaries;
+ if (!binaries.Initialize(true, dist) && !binaries.Initialize(false, dist))
grt (UTC plus 2) 2013/01/24 02:51:40 eula only applies to system-level installs. you sh
huangs 2013/01/24 18:56:03 Done. Also added logic to return EULA_YES when qu
+ return E_FAIL;
+
+ // Is Omaha waiting for Chrome's EULA to be accepted?
+ DWORD eula_accepted = 0;
+ if (binaries.GetEulaAccepted(&eula_accepted) && !eula_accepted)
+ return 0;
+
+ // Has the current user been through first-run?
+ if (!IsChromeFirstRun(dist))
grt (UTC plus 2) 2013/01/24 02:51:40 use the BrowserDistribution::CHROME_BROWSER instan
huangs 2013/01/24 18:56:03 Done.
+ return 1;
+
grt (UTC plus 2) 2013/01/24 02:51:40 is the result the same if the EULA sentinel check
huangs 2013/01/24 18:56:03 It's a bit bizarre since we check for "yes" before
grt (UTC plus 2) 2013/01/24 21:04:55 it's an optimization. the cost of parsing master_p
+ scoped_ptr<MasterPreferences> install_prefs(GetNewMasterPrefs());
+ if (!install_prefs.get())
grt (UTC plus 2) 2013/01/24 02:51:40 if (!install_prefs)
huangs 2013/01/24 18:56:03 Done.
+ return 0;
+
+ if (!IsEULARequiredInMasterPrefs(install_prefs.get()))
+ return 1;
+
+ return IsEULASentinelPresent(dist) ? 1 : 0;
+}
+
+} // namespace installer

Powered by Google App Engine
This is Rietveld 408576698