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

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: Addressed comments 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"
24 #include "ui/arc/notification/arc_notification_manager.h" 26 #include "ui/arc/notification/arc_notification_manager.h"
25 27
26 namespace arc { 28 namespace arc {
27 29
28 namespace { 30 namespace {
29 31
30 // Weak pointer. This class is owned by ChromeBrowserMainPartsChromeos. 32 // Weak pointer. This class is owned by ChromeBrowserMainPartsChromeos.
31 ArcServiceManager* g_arc_service_manager = nullptr; 33 ArcServiceManager* g_arc_service_manager = nullptr;
32 34
33 // This pointer is owned by ArcServiceManager. 35 // This pointer is owned by ArcServiceManager.
(...skipping 19 matching lines...) Expand all
53 AddService(base::WrapUnique(new ArcBluetoothBridge(arc_bridge_service()))); 55 AddService(base::WrapUnique(new ArcBluetoothBridge(arc_bridge_service())));
54 AddService(base::WrapUnique(new ArcClipboardBridge(arc_bridge_service()))); 56 AddService(base::WrapUnique(new ArcClipboardBridge(arc_bridge_service())));
55 AddService( 57 AddService(
56 base::WrapUnique(new ArcCrashCollectorBridge(arc_bridge_service()))); 58 base::WrapUnique(new ArcCrashCollectorBridge(arc_bridge_service())));
57 AddService(base::WrapUnique(new ArcImeService(arc_bridge_service()))); 59 AddService(base::WrapUnique(new ArcImeService(arc_bridge_service())));
58 AddService(base::WrapUnique(new ArcIntentHelperBridge(arc_bridge_service()))); 60 AddService(base::WrapUnique(new ArcIntentHelperBridge(arc_bridge_service())));
59 AddService(base::WrapUnique(new ArcMetricsService(arc_bridge_service()))); 61 AddService(base::WrapUnique(new ArcMetricsService(arc_bridge_service())));
60 AddService(base::WrapUnique(new ArcNetHostImpl(arc_bridge_service()))); 62 AddService(base::WrapUnique(new ArcNetHostImpl(arc_bridge_service())));
61 AddService(base::WrapUnique(new ArcPowerBridge(arc_bridge_service()))); 63 AddService(base::WrapUnique(new ArcPowerBridge(arc_bridge_service())));
62 AddService(base::WrapUnique(new ArcStorageManager(arc_bridge_service()))); 64 AddService(base::WrapUnique(new ArcStorageManager(arc_bridge_service())));
65
66 arc_user_data_service_ = base::MakeUnique<ArcUserDataService>(this);
63 } 67 }
64 68
65 ArcServiceManager::~ArcServiceManager() { 69 ArcServiceManager::~ArcServiceManager() {
66 DCHECK(thread_checker_.CalledOnValidThread()); 70 DCHECK(thread_checker_.CalledOnValidThread());
67 DCHECK(g_arc_service_manager == this); 71 DCHECK(g_arc_service_manager == this);
68 g_arc_service_manager = nullptr; 72 g_arc_service_manager = nullptr;
69 if (g_arc_bridge_service_for_testing) { 73 if (g_arc_bridge_service_for_testing) {
70 delete g_arc_bridge_service_for_testing; 74 delete g_arc_bridge_service_for_testing;
71 } 75 }
72 } 76 }
(...skipping 10 matching lines...) Expand all
83 return arc_bridge_service_.get(); 87 return arc_bridge_service_.get();
84 } 88 }
85 89
86 void ArcServiceManager::AddService(std::unique_ptr<ArcService> service) { 90 void ArcServiceManager::AddService(std::unique_ptr<ArcService> service) {
87 DCHECK(thread_checker_.CalledOnValidThread()); 91 DCHECK(thread_checker_.CalledOnValidThread());
88 92
89 services_.emplace_back(std::move(service)); 93 services_.emplace_back(std::move(service));
90 } 94 }
91 95
92 void ArcServiceManager::OnPrimaryUserProfilePrepared( 96 void ArcServiceManager::OnPrimaryUserProfilePrepared(
93 const AccountId& account_id) { 97 const AccountId& account_id,
98 std::unique_ptr<BooleanPrefMember> arc_enabled_pref) {
94 DCHECK(thread_checker_.CalledOnValidThread()); 99 DCHECK(thread_checker_.CalledOnValidThread());
100 arc_enabled_pref_ = std::move(arc_enabled_pref);
95 101
102 arc_user_data_service_->ClearIfDisabled(account_id);
96 AddService(base::WrapUnique( 103 AddService(base::WrapUnique(
97 new ArcNotificationManager(arc_bridge_service(), account_id))); 104 new ArcNotificationManager(arc_bridge_service(), account_id)));
98 } 105 }
99 106
107 bool ArcServiceManager::IsArcEnabled() const {
108 DCHECK(thread_checker_.CalledOnValidThread());
109 return arc_enabled_pref_ && arc_enabled_pref_->GetValue();
110 }
111
100 void ArcServiceManager::OnAshStarted() { 112 void ArcServiceManager::OnAshStarted() {
101 DCHECK(thread_checker_.CalledOnValidThread()); 113 DCHECK(thread_checker_.CalledOnValidThread());
102 // We might come here multiple times. As such we should only do this once. 114 // We might come here multiple times. As such we should only do this once.
103 if (on_ash_started_called_) 115 if (on_ash_started_called_)
104 return; 116 return;
105 117
106 on_ash_started_called_ = true; 118 on_ash_started_called_ = true;
107 AddService( 119 AddService(
108 base::WrapUnique(new ArcWindowManagerBridge(arc_bridge_service()))); 120 base::WrapUnique(new ArcWindowManagerBridge(arc_bridge_service())));
109 } 121 }
110 122
111 void ArcServiceManager::Shutdown() { 123 void ArcServiceManager::Shutdown() {
112 services_.clear(); 124 services_.clear();
113 } 125 }
114 126
115 //static 127 //static
116 void ArcServiceManager::SetArcBridgeServiceForTesting( 128 void ArcServiceManager::SetArcBridgeServiceForTesting(
117 std::unique_ptr<ArcBridgeService> arc_bridge_service) { 129 std::unique_ptr<ArcBridgeService> arc_bridge_service) {
118 if (g_arc_bridge_service_for_testing) { 130 if (g_arc_bridge_service_for_testing) {
119 delete g_arc_bridge_service_for_testing; 131 delete g_arc_bridge_service_for_testing;
120 } 132 }
121 g_arc_bridge_service_for_testing = arc_bridge_service.release(); 133 g_arc_bridge_service_for_testing = arc_bridge_service.release();
122 } 134 }
123 135
124 } // namespace arc 136 } // namespace arc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698