Chromium Code Reviews| Index: chrome/browser/chromeos/policy/consumer_management_service.cc |
| diff --git a/chrome/browser/chromeos/policy/consumer_management_service.cc b/chrome/browser/chromeos/policy/consumer_management_service.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..63c74bdbd2ce1605cafcec2856d99b5ace122f68 |
| --- /dev/null |
| +++ b/chrome/browser/chromeos/policy/consumer_management_service.cc |
| @@ -0,0 +1,114 @@ |
| +// Copyright 2014 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/policy/consumer_management_service.h" |
| + |
| +#include "base/bind.h" |
| +#include "base/logging.h" |
| +#include "base/prefs/pref_registry_simple.h" |
| +#include "base/prefs/pref_service.h" |
| +#include "chrome/browser/browser_process.h" |
| +#include "chrome/common/pref_names.h" |
| +#include "chromeos/dbus/cryptohome/rpc.pb.h" |
| +#include "chromeos/dbus/cryptohome_client.h" |
| + |
| +namespace policy { |
| + |
| +const char* ConsumerManagementService::kDeviceOwner = |
| + "consumer_management.owner"; |
| + |
| +// static |
| +void ConsumerManagementService::RegisterPrefs(PrefRegistrySimple* registry) { |
| + registry->RegisterIntegerPref( |
| + prefs::kConsumerManagementEnrollState, ENROLL_NONE); |
| +} |
| + |
| +ConsumerManagementService::ConsumerManagementService( |
| + chromeos::CryptohomeClient* client) : client_(client), |
| + weak_ptr_factory_(this) { |
| +} |
| + |
| +ConsumerManagementService::EnrollState |
| + ConsumerManagementService::GetEnrollState() { |
|
bartfab (slow)
2014/08/04 18:44:51
Nit: The style guide says that if you break betwee
davidyu
2014/08/05 07:26:58
Done.
|
| + PrefService* prefs = g_browser_process->local_state(); |
| + return static_cast<EnrollState>(prefs->GetInteger( |
|
bartfab (slow)
2014/08/04 18:44:51
What if the pref value is outside the valid range?
davidyu
2014/08/05 07:26:58
Added error handling code.
|
| + prefs::kConsumerManagementEnrollState)); |
| +} |
| + |
| +void ConsumerManagementService::SetEnrollState(EnrollState state) { |
| + PrefService* prefs = g_browser_process->local_state(); |
| + prefs->SetInteger(prefs::kConsumerManagementEnrollState, state); |
| + prefs->CommitPendingWrite(); |
|
bartfab (slow)
2014/08/04 18:44:51
Why? Prefs get auto-committed for you.
davidyu
2014/08/05 07:26:58
If we call PowerManagementClient::RequestRestart()
bartfab (slow)
2014/08/05 18:07:13
During a clean browser shutdown, pending writes ar
davidyu
2014/08/06 03:04:31
RequestRestart() eventually runs "shutdown -r now"
|
| +} |
| + |
| +void ConsumerManagementService::GetOwner( |
| + const base::Callback<void(const std::string&)>& callback) { |
| + cryptohome::GetBootAttributeRequest request; |
| + request.set_name(kDeviceOwner); |
| + client_->GetBootAttribute( |
| + request, |
| + base::Bind(&ConsumerManagementService::OnGetBootAttributeDone, |
| + weak_ptr_factory_.GetWeakPtr(), callback)); |
|
bartfab (slow)
2014/08/04 18:44:51
Nit: Put each argument on a separate line.
davidyu
2014/08/05 07:26:58
Done.
|
| +} |
| + |
| +void ConsumerManagementService::OnGetBootAttributeDone( |
| + const base::Callback<void(const std::string&)>& callback, |
| + chromeos::DBusMethodCallStatus call_status, |
| + bool result, |
| + const cryptohome::BaseReply& reply) { |
| + if (!result || reply.error() != 0) { |
| + LOG(ERROR) << "Failed to get the owner info from boot lockbox."; |
| + callback.Run(""); |
| + return; |
| + } |
| + |
| + callback.Run( |
| + reply.GetExtension(cryptohome::GetBootAttributeReply::reply).value()); |
| +} |
| + |
| +void ConsumerManagementService::SetOwner( |
| + const std::string& email, |
| + const base::Callback<void(bool)>& callback) { |
| + cryptohome::SetBootAttributeRequest request; |
| + request.set_name(kDeviceOwner); |
| + request.set_value(email.data(), email.size()); |
| + client_->SetBootAttribute( |
| + request, |
| + base::Bind(&ConsumerManagementService::OnSetBootAttributeDone, |
| + weak_ptr_factory_.GetWeakPtr(), callback)); |
|
bartfab (slow)
2014/08/04 18:44:51
Nit: Put each argument on a separate line.
davidyu
2014/08/05 07:26:58
Done.
|
| +} |
| + |
| +void ConsumerManagementService::OnSetBootAttributeDone( |
| + const base::Callback<void(bool)>& callback, |
| + chromeos::DBusMethodCallStatus call_status, |
| + bool result, |
| + const cryptohome::BaseReply& reply) { |
| + if (!result || reply.error() != 0) { |
| + LOG(ERROR) << "Failed to set owner info in boot lockbox."; |
| + callback.Run(false); |
| + return; |
| + } |
| + |
| + cryptohome::FlushAndSignBootAttributesRequest request; |
| + client_->FlushAndSignBootAttributes( |
| + request, |
| + base::Bind(&ConsumerManagementService::OnFlushAndSignBootAttributesDone, |
| + weak_ptr_factory_.GetWeakPtr(), callback)); |
|
bartfab (slow)
2014/08/04 18:44:51
Nit: Put each argument on a separate line.
davidyu
2014/08/05 07:26:58
Done.
|
| +} |
| + |
| +void ConsumerManagementService::OnFlushAndSignBootAttributesDone( |
| + const base::Callback<void(bool)>& callback, |
| + chromeos::DBusMethodCallStatus call_status, |
| + bool result, |
| + const cryptohome::BaseReply& reply) { |
| + if (!result || reply.error() != 0) { |
| + LOG(ERROR) << "Failed to flush and sign boot lockbox."; |
| + callback.Run(false); |
| + return; |
| + } |
| + |
| + callback.Run(true); |
| +} |
| + |
| +} // namespace policy |