Index: chrome/browser/chromeos/arc/arc_data_manager.cc |
diff --git a/chrome/browser/chromeos/arc/arc_data_manager.cc b/chrome/browser/chromeos/arc/arc_data_manager.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..a8a98dae96944749aad232054591179e184a409b |
--- /dev/null |
+++ b/chrome/browser/chromeos/arc/arc_data_manager.cc |
@@ -0,0 +1,66 @@ |
+// Copyright 2016 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/browser/chromeos/arc/arc_data_manager.h" |
+ |
+#include "chrome/browser/chromeos/profiles/profile_helper.h" |
+#include "chrome/browser/profiles/profile.h" |
+#include "chrome/common/pref_names.h" |
+#include "chromeos/dbus/dbus_thread_manager.h" |
+#include "chromeos/dbus/session_manager_client.h" |
+#include "components/prefs/pref_service.h" |
+#include "components/user_manager/user.h" |
+ |
+namespace arc { |
+ |
+namespace { |
+ |
+// Weak Pointer. This class is owned by ChromeBrowserMainPartsChromeos. |
+ArcDataManager* g_arc_data_manager = nullptr; |
+ |
+} // namespace |
+ |
+ArcDataManager::ArcDataManager() { |
+ DCHECK(!g_arc_data_manager); |
+ g_arc_data_manager = this; |
+ ArcBridgeService::Get()->AddObserver(this); |
+} |
+ |
+ArcDataManager::~ArcDataManager() { |
+ DCHECK(thread_checker_.CalledOnValidThread()); |
+ DCHECK(g_arc_data_manager == this); |
+ ArcBridgeService::Get()->RemoveObserver(this); |
+ g_arc_data_manager = nullptr; |
+} |
+ |
+// static |
+ArcDataManager* ArcDataManager::Get() { |
+ DCHECK(g_arc_data_manager); |
+ DCHECK(g_arc_data_manager->thread_checker_.CalledOnValidThread()); |
+ return g_arc_data_manager; |
+} |
+ |
+void ArcDataManager::OnStateChanged(ArcBridgeService::State state) { |
+ DCHECK(g_arc_data_manager->thread_checker_.CalledOnValidThread()); |
+ if (state != ArcBridgeService::State::STOPPED) { |
+ return; |
+ } |
+ const user_manager::User* const primary_user = |
+ user_manager::UserManager::Get()->GetPrimaryUser(); |
stevenjb
2016/05/13 17:13:55
nit: The extra const here and in line 51 is a bit
dspaid
2016/05/15 23:58:51
Probably a copy/paste bug on my side.
|
+ Profile* const profile = |
+ chromeos::ProfileHelper::Get()->GetProfileByUser(primary_user); |
+ ClearIfDisabled(profile); |
+} |
+ |
+void ArcDataManager::ClearIfDisabled(Profile* profile) { |
+ DCHECK(g_arc_data_manager->thread_checker_.CalledOnValidThread()); |
+ DCHECK(ArcBridgeService::Get()->state() == ArcBridgeService::State::STOPPED); |
stevenjb
2016/05/13 17:13:55
Is the calling code logically protected against th
dspaid
2016/05/15 23:58:51
Done.
|
+ if (!profile->GetPrefs()->GetBoolean(prefs::kArcEnabled)) { |
stevenjb
2016/05/13 17:13:54
nit: Invert and early exit
dspaid
2016/05/15 23:58:51
Done.
|
+ chromeos::SessionManagerClient* session_manager_client = |
+ chromeos::DBusThreadManager::Get()->GetSessionManagerClient(); |
+ session_manager_client->RemoveArcData(); |
+ } |
+} |
+ |
+} // namespace arc |