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

Side by Side Diff: components/arc/arc_service_manager.cc

Issue 1966133002: Run RemoveArcData after a user has opted out (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: clean up boolean logic Created 4 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "components/arc/arc_service_manager.h" 5 #include "components/arc/arc_service_manager.h"
6 6
7 #include "base/memory/ptr_util.h" 7 #include "base/memory/ptr_util.h"
8 #include "base/sequenced_task_runner.h" 8 #include "base/sequenced_task_runner.h"
9 #include "base/threading/thread_task_runner_handle.h" 9 #include "base/threading/thread_task_runner_handle.h"
10 #include "components/arc/arc_bridge_bootstrap.h" 10 #include "components/arc/arc_bridge_bootstrap.h"
11 #include "components/arc/arc_bridge_service.h" 11 #include "components/arc/arc_bridge_service.h"
12 #include "components/arc/arc_bridge_service_impl.h" 12 #include "components/arc/arc_bridge_service_impl.h"
13 #include "components/arc/audio/arc_audio_bridge.h" 13 #include "components/arc/audio/arc_audio_bridge.h"
14 #include "components/arc/bluetooth/arc_bluetooth_bridge.h" 14 #include "components/arc/bluetooth/arc_bluetooth_bridge.h"
15 #include "components/arc/clipboard/arc_clipboard_bridge.h" 15 #include "components/arc/clipboard/arc_clipboard_bridge.h"
16 #include "components/arc/crash_collector/arc_crash_collector_bridge.h" 16 #include "components/arc/crash_collector/arc_crash_collector_bridge.h"
17 #include "components/arc/ime/arc_ime_service.h" 17 #include "components/arc/ime/arc_ime_service.h"
18 #include "components/arc/intent_helper/arc_intent_helper_bridge.h" 18 #include "components/arc/intent_helper/arc_intent_helper_bridge.h"
19 #include "components/arc/metrics/arc_metrics_service.h" 19 #include "components/arc/metrics/arc_metrics_service.h"
20 #include "components/arc/net/arc_net_host_impl.h" 20 #include "components/arc/net/arc_net_host_impl.h"
21 #include "components/arc/power/arc_power_bridge.h" 21 #include "components/arc/power/arc_power_bridge.h"
22 #include "components/arc/storage_manager/arc_storage_manager.h" 22 #include "components/arc/storage_manager/arc_storage_manager.h"
23 #include "components/arc/user_data/arc_user_data_service.h"
23 #include "components/arc/window_manager/arc_window_manager_bridge.h" 24 #include "components/arc/window_manager/arc_window_manager_bridge.h"
25 #include "components/prefs/pref_member.h"
26 #include "components/prefs/pref_service.h"
24 #include "ui/arc/notification/arc_notification_manager.h" 27 #include "ui/arc/notification/arc_notification_manager.h"
25 28
26 namespace arc { 29 namespace arc {
27 30
28 namespace { 31 namespace {
29 32
30 // Weak pointer. This class is owned by ChromeBrowserMainPartsChromeos. 33 // Weak pointer. This class is owned by ChromeBrowserMainPartsChromeos.
31 ArcServiceManager* g_arc_service_manager = nullptr; 34 ArcServiceManager* g_arc_service_manager = nullptr;
32 35
33 // This pointer is owned by ArcServiceManager. 36 // This pointer is owned by ArcServiceManager.
(...skipping 19 matching lines...) Expand all
53 AddService(base::WrapUnique(new ArcBluetoothBridge(arc_bridge_service()))); 56 AddService(base::WrapUnique(new ArcBluetoothBridge(arc_bridge_service())));
54 AddService(base::WrapUnique(new ArcClipboardBridge(arc_bridge_service()))); 57 AddService(base::WrapUnique(new ArcClipboardBridge(arc_bridge_service())));
55 AddService( 58 AddService(
56 base::WrapUnique(new ArcCrashCollectorBridge(arc_bridge_service()))); 59 base::WrapUnique(new ArcCrashCollectorBridge(arc_bridge_service())));
57 AddService(base::WrapUnique(new ArcImeService(arc_bridge_service()))); 60 AddService(base::WrapUnique(new ArcImeService(arc_bridge_service())));
58 AddService(base::WrapUnique(new ArcIntentHelperBridge(arc_bridge_service()))); 61 AddService(base::WrapUnique(new ArcIntentHelperBridge(arc_bridge_service())));
59 AddService(base::WrapUnique(new ArcMetricsService(arc_bridge_service()))); 62 AddService(base::WrapUnique(new ArcMetricsService(arc_bridge_service())));
60 AddService(base::WrapUnique(new ArcNetHostImpl(arc_bridge_service()))); 63 AddService(base::WrapUnique(new ArcNetHostImpl(arc_bridge_service())));
61 AddService(base::WrapUnique(new ArcPowerBridge(arc_bridge_service()))); 64 AddService(base::WrapUnique(new ArcPowerBridge(arc_bridge_service())));
62 AddService(base::WrapUnique(new ArcStorageManager(arc_bridge_service()))); 65 AddService(base::WrapUnique(new ArcStorageManager(arc_bridge_service())));
66
67 arc_user_data_service_.reset(new ArcUserDataService(this));
Luis Héctor Chávez 2016/05/20 15:03:58 nit: arc_user_data_service_ = base::MakeUnique<Arc
dspaid 2016/05/23 01:22:36 Done.
63 } 68 }
64 69
65 ArcServiceManager::~ArcServiceManager() { 70 ArcServiceManager::~ArcServiceManager() {
66 DCHECK(thread_checker_.CalledOnValidThread()); 71 DCHECK(thread_checker_.CalledOnValidThread());
67 DCHECK(g_arc_service_manager == this); 72 DCHECK(g_arc_service_manager == this);
68 g_arc_service_manager = nullptr; 73 g_arc_service_manager = nullptr;
69 if (g_arc_bridge_service_for_testing) { 74 if (g_arc_bridge_service_for_testing) {
70 delete g_arc_bridge_service_for_testing; 75 delete g_arc_bridge_service_for_testing;
71 } 76 }
77 if (arc_enabled_pref_)
Daniel Erat 2016/05/20 17:41:05 it doesn't seem like you need this. PrefMemberBase
dspaid 2016/05/23 01:22:36 Done.
78 arc_enabled_pref_->Destroy();
72 } 79 }
73 80
74 // static 81 // static
75 ArcServiceManager* ArcServiceManager::Get() { 82 ArcServiceManager* ArcServiceManager::Get() {
76 DCHECK(g_arc_service_manager); 83 DCHECK(g_arc_service_manager);
77 DCHECK(g_arc_service_manager->thread_checker_.CalledOnValidThread()); 84 DCHECK(g_arc_service_manager->thread_checker_.CalledOnValidThread());
78 return g_arc_service_manager; 85 return g_arc_service_manager;
79 } 86 }
80 87
81 ArcBridgeService* ArcServiceManager::arc_bridge_service() { 88 ArcBridgeService* ArcServiceManager::arc_bridge_service() {
82 DCHECK(thread_checker_.CalledOnValidThread()); 89 DCHECK(thread_checker_.CalledOnValidThread());
83 return arc_bridge_service_.get(); 90 return arc_bridge_service_.get();
84 } 91 }
85 92
86 void ArcServiceManager::AddService(std::unique_ptr<ArcService> service) { 93 void ArcServiceManager::AddService(std::unique_ptr<ArcService> service) {
87 DCHECK(thread_checker_.CalledOnValidThread()); 94 DCHECK(thread_checker_.CalledOnValidThread());
88 95
89 services_.emplace_back(std::move(service)); 96 services_.emplace_back(std::move(service));
90 } 97 }
91 98
92 void ArcServiceManager::OnPrimaryUserProfilePrepared( 99 void ArcServiceManager::OnPrimaryUserProfilePrepared(
93 const AccountId& account_id) { 100 const AccountId& account_id,
101 PrefService* pref_service,
102 std::string pref_name) {
103 if (arc_enabled_pref_)
Luis Héctor Chávez 2016/05/20 15:03:58 DCHECK(thread_checker_.CalledOnValidThread());
dspaid 2016/05/23 01:22:36 Done.
104 arc_enabled_pref_->Destroy();
Daniel Erat 2016/05/20 17:41:05 you shouldn't need this here either
dspaid 2016/05/23 01:22:36 Done.
105 arc_enabled_pref_ = std::unique_ptr<BooleanPrefMember>(
Luis Héctor Chávez 2016/05/20 15:03:58 nit: arc_enabled_pref_ = base::MakeUnique<BooleanP
dspaid 2016/05/23 01:22:36 Acknowledged.
106 new BooleanPrefMember());
107 arc_enabled_pref_->Init(pref_name, pref_service);
94 DCHECK(thread_checker_.CalledOnValidThread()); 108 DCHECK(thread_checker_.CalledOnValidThread());
95 109
110 arc_user_data_service_->ClearIfDisabled(account_id);
96 AddService(base::WrapUnique( 111 AddService(base::WrapUnique(
97 new ArcNotificationManager(arc_bridge_service(), account_id))); 112 new ArcNotificationManager(arc_bridge_service(), account_id)));
98 } 113 }
99 114
115 bool ArcServiceManager::IsArcEnabled() {
116 return arc_enabled_pref_ && arc_enabled_pref_->GetValue();
Luis Héctor Chávez 2016/05/20 15:03:58 DCHECK(thread_checker_.CalledOnValidThread());
dspaid 2016/05/23 01:22:36 Done.
117 }
118
100 void ArcServiceManager::OnAshStarted() { 119 void ArcServiceManager::OnAshStarted() {
101 DCHECK(thread_checker_.CalledOnValidThread()); 120 DCHECK(thread_checker_.CalledOnValidThread());
102 // We might come here multiple times. As such we should only do this once. 121 // We might come here multiple times. As such we should only do this once.
103 if (on_ash_started_called_) 122 if (on_ash_started_called_)
104 return; 123 return;
105 124
106 on_ash_started_called_ = true; 125 on_ash_started_called_ = true;
107 AddService( 126 AddService(
108 base::WrapUnique(new ArcWindowManagerBridge(arc_bridge_service()))); 127 base::WrapUnique(new ArcWindowManagerBridge(arc_bridge_service())));
109 } 128 }
110 129
111 void ArcServiceManager::Shutdown() { 130 void ArcServiceManager::Shutdown() {
112 services_.clear(); 131 services_.clear();
113 } 132 }
114 133
115 //static 134 //static
116 void ArcServiceManager::SetArcBridgeServiceForTesting( 135 void ArcServiceManager::SetArcBridgeServiceForTesting(
117 std::unique_ptr<ArcBridgeService> arc_bridge_service) { 136 std::unique_ptr<ArcBridgeService> arc_bridge_service) {
118 if (g_arc_bridge_service_for_testing) { 137 if (g_arc_bridge_service_for_testing) {
119 delete g_arc_bridge_service_for_testing; 138 delete g_arc_bridge_service_for_testing;
120 } 139 }
121 g_arc_bridge_service_for_testing = arc_bridge_service.release(); 140 g_arc_bridge_service_for_testing = arc_bridge_service.release();
122 } 141 }
123 142
124 } // namespace arc 143 } // namespace arc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698