Chromium Code Reviews| Index: components/arc/user_data/arc_user_data_service.cc |
| diff --git a/components/arc/user_data/arc_user_data_service.cc b/components/arc/user_data/arc_user_data_service.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..7af43642f2fc4622136650183b885e86b21b742e |
| --- /dev/null |
| +++ b/components/arc/user_data/arc_user_data_service.cc |
| @@ -0,0 +1,61 @@ |
| +// 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 "components/arc/user_data/arc_user_data_service.h" |
| + |
| +#include "chromeos/cryptohome/cryptohome_parameters.h" |
| +#include "chromeos/dbus/dbus_thread_manager.h" |
| +#include "chromeos/dbus/session_manager_client.h" |
| +#include "components/prefs/pref_member.h" |
| +#include "components/signin/core/account_id/account_id.h" |
| +#include "components/user_manager/user_manager.h" |
| + |
| +namespace arc { |
| + |
| +ArcUserDataService::ArcUserDataService( |
| + ArcBridgeService* bridge_service, |
| + std::unique_ptr<BooleanPrefMember> arc_enabled_pref) |
| + : ArcService(bridge_service), |
| + arc_enabled_pref_(std::move(arc_enabled_pref)) {} |
|
hidehiko
2016/06/14 05:13:02
I think, you accidentally removed AddObserver from
dspaid
2016/06/14 05:40:54
Done.
|
| + |
| +ArcUserDataService::~ArcUserDataService() { |
| + DCHECK(thread_checker_.CalledOnValidThread()); |
| + arc_bridge_service()->RemoveObserver(this); |
| +} |
| + |
| +void ArcUserDataService::OnBridgeStopped() { |
| + DCHECK(thread_checker_.CalledOnValidThread()); |
| + const AccountId& account_id = |
| + user_manager::UserManager::Get()->GetPrimaryUser()->GetAccountId(); |
| + if (account_id != primary_user_account_id_) { |
| + LOG(ERROR) << "User preferences not loaded for " |
| + << primary_user_account_id_.GetUserEmail() |
| + << ", but current primary user is " << account_id.GetUserEmail(); |
| + primary_user_account_id_ = EmptyAccountId(); |
| + return; |
| + } |
| + ClearIfDisabled(); |
| +} |
| + |
| +void ArcUserDataService::OnPrimaryUserProfilePrepared( |
| + const AccountId& account_id) { |
|
hidehiko
2016/06/14 05:13:01
Could you pass this to the ctor, too, to be aligne
dspaid
2016/06/14 05:40:54
Done.
|
| + primary_user_account_id_ = account_id; |
| + ClearIfDisabled(); |
|
hidehiko
2016/06/14 05:13:01
nit: Maybe move this to ctor, too?
dspaid
2016/06/14 05:40:54
Done.
|
| +} |
| + |
| +void ArcUserDataService::ClearIfDisabled() { |
| + DCHECK(thread_checker_.CalledOnValidThread()); |
| + if (arc_bridge_service()->state() != ArcBridgeService::State::STOPPED) { |
| + LOG(ERROR) << "ARC instance not stopped, user data can't be cleared"; |
| + return; |
| + } |
| + if (arc_enabled_pref_->GetValue()) |
| + return; |
| + const cryptohome::Identification cryptohome_id(primary_user_account_id_); |
| + chromeos::SessionManagerClient* session_manager_client = |
| + chromeos::DBusThreadManager::Get()->GetSessionManagerClient(); |
| + session_manager_client->RemoveArcData(cryptohome_id); |
| +} |
| + |
| +} // namespace arc |