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

Unified Diff: chrome/browser/chromeos/arc/arc_util.cc

Issue 2890843002: Policy implementation for encryptfs to ext4 migration strategy (Closed)
Patch Set: Fixed review comments Created 3 years, 6 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/chromeos/arc/arc_util.cc
diff --git a/chrome/browser/chromeos/arc/arc_util.cc b/chrome/browser/chromeos/arc/arc_util.cc
index 151e460102347687ef2f92dbfa9b67848a15f2de..2ba67f186557b3686f2de82aca0dda35a1f74eab 100644
--- a/chrome/browser/chromeos/arc/arc_util.cc
+++ b/chrome/browser/chromeos/arc/arc_util.cc
@@ -8,17 +8,22 @@
#include <sys/statfs.h>
#include "base/callback.h"
+#include "base/command_line.h"
#include "base/files/file_path.h"
#include "base/logging.h"
#include "base/sys_info.h"
#include "base/task_scheduler/post_task.h"
#include "base/threading/thread_restrictions.h"
+#include "chrome/browser/browser_process.h"
#include "chrome/browser/chromeos/arc/arc_session_manager.h"
#include "chrome/browser/chromeos/login/user_flow.h"
#include "chrome/browser/chromeos/login/users/chrome_user_manager.h"
+#include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h"
+#include "chrome/browser/chromeos/policy/proto/chrome_device_policy.pb.h"
#include "chrome/browser/chromeos/profiles/profile_helper.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/common/pref_names.h"
+#include "chromeos/chromeos_switches.h"
#include "components/arc/arc_util.h"
#include "components/prefs/pref_service.h"
#include "components/user_manager/known_user.h"
@@ -39,6 +44,11 @@ bool g_disallow_for_testing = false;
// during test runs.
bool g_arc_blocked_due_to_incomaptible_filesystem_for_testing = false;
+// This flag is set the first time the check if migration to ext4 is allowed,
+// and remains unchanged after that.
+// TODO(igorcov): Remove this after migration. crbug.com/725493
+base::Optional<bool> g_is_arc_migration_allowed;
bartfab (slow) 2017/06/12 12:49:03 Nit: #include "base/optional.h"
igorcov 2017/06/12 16:50:09 Done.
+
// Returns whether ARC can run on the filesystem mounted at |path|.
// This function should run only on threads where IO operations are allowed.
bool IsArcCompatibleFilesystem(const base::FilePath& path) {
@@ -72,6 +82,33 @@ FileSystemCompatibilityState GetFileSystemCompatibilityPref(
return static_cast<FileSystemCompatibilityState>(pref_value);
}
+bool IsArcMigrationAllowedInternal() {
+ // If the device is not managed, then the migration allowed.
+ if (!g_browser_process->platform_part()
bartfab (slow) 2017/06/12 12:49:03 Nit: #include "chrome/browser/browser_process_plat
igorcov 2017/06/12 16:50:09 Done.
+ ->browser_policy_connector_chromeos()
+ ->IsEnterpriseManaged()) {
+ return true;
+ }
+
+ const auto* command_line = base::CommandLine::ForCurrentProcess();
bartfab (slow) 2017/06/12 12:49:04 Nit: const pointer to const
igorcov 2017/06/12 16:50:09 Done.
+ // If the command line flag is missing, the migration for this type of
+ // device is allowed regardless of the policy data.
+ if (!command_line->HasSwitch(
+ chromeos::switches::kNeedArcMigrationPolicyCheck)) {
+ return true;
+ }
+
+ const PrefService* pref_service =
bartfab (slow) 2017/06/12 12:49:03 Nit: const pointer to const
igorcov 2017/06/12 16:50:09 Done.
+ user_manager::UserManager::Get()->GetLocalState();
+ const PrefService::Preference* pref =
bartfab (slow) 2017/06/12 12:49:04 Nit: const pointer to const
igorcov 2017/06/12 16:50:09 Done.
+ pref_service->FindPreference(prefs::kDeviceEcryptfsMigrationStrategy);
+
+ return pref && pref->GetValue() &&
+ pref->GetValue()->GetInt() ==
bartfab (slow) 2017/06/12 12:49:03 Nit: #include "base/values.h"
igorcov 2017/06/12 16:50:09 Done.
+ enterprise_management::DeviceEcryptfsMigrationStrategyProto::
+ ALLOW_MIGRATION;
+}
+
} // namespace
bool IsArcAllowedForProfile(const Profile* profile) {
kinaba 2017/06/12 00:22:07 Returning false from this utility method does not
igorcov 2017/06/12 16:50:09 Added additional checks for migration UI. Thank yo
@@ -121,6 +158,22 @@ bool IsArcAllowedForProfile(const Profile* profile) {
return false;
}
+ // If migration policy check is needed (specified by commandline flag), check
+ // the policy, which should be already available here. If policy says
+ // migration is not allowed, do not run ARC, regardless whether file system
+ // migration is actually needed. For example, even if file system is still
+ // ecryptfs and ARC version is M, or file system is already migrated into ext4
+ // crypt and ARC version is N or later, if policy says migration is not
+ // allowed, ARC will never run. Practically, in the former example case,
+ // --need-arc-migration-policy-check is not set, so this check passes and user
+ // can use ARC. In latter case, policy should say migration is allowed, so
+ // also user can use ARC then.
+ // TODO(igorcov): Remove this after migration. crbug.com/725493
+ if (!IsArcMigrationAllowed()) {
+ VLOG(1) << "ARC requires migration, but is not allowed by the policy.";
bartfab (slow) 2017/06/12 12:49:04 Nit: The log statement contradicts the comment abo
igorcov 2017/06/12 16:50:09 Fixed the log statement.
+ return false;
+ }
+
// Do not run ARC instance when supervised user is being created.
// Otherwise noisy notification may be displayed.
chromeos::UserFlow* user_flow =
@@ -261,4 +314,14 @@ void UpdateArcFileSystemCompatibilityPrefIfNeeded(
base::Bind(&StoreCompatibilityCheckResult, account_id, callback));
}
+bool IsArcMigrationAllowed() {
+ if (!g_is_arc_migration_allowed.has_value())
+ g_is_arc_migration_allowed = IsArcMigrationAllowedInternal();
+ return g_is_arc_migration_allowed.value();
+}
+
+void ResetArcMigrationAllowedForTesting() {
+ g_is_arc_migration_allowed.reset();
+}
+
} // namespace arc

Powered by Google App Engine
This is Rietveld 408576698