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

Unified Diff: chrome/browser/chromeos/login/enrollment/auto_enrollment_controller.cc

Issue 2727713003: Update FWMP in TPM (Closed)
Patch Set: Fixed reenrollment case Created 3 years, 9 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/chromeos/login/enrollment/auto_enrollment_controller.cc
diff --git a/chrome/browser/chromeos/login/enrollment/auto_enrollment_controller.cc b/chrome/browser/chromeos/login/enrollment/auto_enrollment_controller.cc
index c21807d27f6701cc968487125f0000f2beec4ffb..b25f9233a8daf77b1645b95412d85c71172c03c4 100644
--- a/chrome/browser/chromeos/login/enrollment/auto_enrollment_controller.cc
+++ b/chrome/browser/chromeos/login/enrollment/auto_enrollment_controller.cc
@@ -13,6 +13,9 @@
#include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h"
#include "chrome/browser/chromeos/policy/server_backed_state_keys_broker.h"
#include "chromeos/chromeos_switches.h"
+#include "chromeos/dbus/cryptohome/rpc.pb.h"
+#include "chromeos/dbus/cryptohome_client.h"
+#include "chromeos/dbus/dbus_thread_manager.h"
#include "chromeos/system/statistics_provider.h"
#include "components/policy/core/common/cloud/device_management_service.h"
#include "net/url_request/url_request_context_getter.h"
@@ -135,7 +138,8 @@ AutoEnrollmentController::Mode AutoEnrollmentController::GetMode() {
AutoEnrollmentController::AutoEnrollmentController()
: state_(policy::AUTO_ENROLLMENT_STATE_IDLE),
safeguard_timer_(false, false),
- client_start_weak_factory_(this) {}
+ client_start_weak_factory_(this),
+ weak_ptr_factory_(this) {}
Thiemo Nagel 2017/03/29 15:46:20 Nit: While you're here, I'd suggest to move initia
igorcov 2017/03/29 16:05:02 Done.
AutoEnrollmentController::~AutoEnrollmentController() {}
@@ -178,9 +182,10 @@ void AutoEnrollmentController::Start() {
}
// Arm the belts-and-suspenders timer to avoid hangs.
- safeguard_timer_.Start(
- FROM_HERE, base::TimeDelta::FromSeconds(kSafeguardTimeoutSeconds),
- base::Bind(&AutoEnrollmentController::Timeout, base::Unretained(this)));
+ safeguard_timer_.Start(FROM_HERE,
+ base::TimeDelta::FromSeconds(kSafeguardTimeoutSeconds),
+ base::Bind(&AutoEnrollmentController::Timeout,
+ weak_ptr_factory_.GetWeakPtr()));
// Start by checking if the device has already been owned.
UpdateState(policy::AUTO_ENROLLMENT_STATE_PENDING);
@@ -271,13 +276,10 @@ void AutoEnrollmentController::StartClient(
client_.reset(new policy::AutoEnrollmentClient(
Thiemo Nagel 2017/03/29 15:46:20 Nit: While you're here, I'd suggest to replace "ne
igorcov 2017/03/29 16:05:02 Done.
base::Bind(&AutoEnrollmentController::UpdateState,
- base::Unretained(this)),
- service,
- g_browser_process->local_state(),
- g_browser_process->system_request_context(),
- state_keys.front(),
- power_initial,
- power_limit));
+ weak_ptr_factory_.GetWeakPtr()),
+ service, g_browser_process->local_state(),
+ g_browser_process->system_request_context(), state_keys.front(),
+ power_initial, power_limit));
VLOG(1) << "Starting auto-enrollment client.";
client_->Start();
@@ -301,6 +303,35 @@ void AutoEnrollmentController::UpdateState(
break;
}
+ if (state_ == policy::AUTO_ENROLLMENT_STATE_NO_ENROLLMENT) {
+ StartRemoveFirmwareManagementParameters();
+ } else {
+ progress_callbacks_.Notify(state_);
+ }
+}
+
+void AutoEnrollmentController::StartRemoveFirmwareManagementParameters() {
+ DCHECK_EQ(policy::AUTO_ENROLLMENT_STATE_NO_ENROLLMENT, state_);
+
+ cryptohome::RemoveFirmwareManagementParametersRequest request;
+ chromeos::DBusThreadManager::Get()
+ ->GetCryptohomeClient()
+ ->RemoveFirmwareManagementParametersFromTpm(
+ request,
+ base::Bind(
+ &AutoEnrollmentController::OnFirmwareManagementParametersRemoved,
+ weak_ptr_factory_.GetWeakPtr()));
+}
+
+void AutoEnrollmentController::OnFirmwareManagementParametersRemoved(
+ chromeos::DBusMethodCallStatus call_status,
+ bool result,
+ const cryptohome::BaseReply& reply) {
+ if (!result) {
+ LOG(ERROR) << "Failed to remove firmware management parameters, error: "
+ << reply.error();
+ }
+
progress_callbacks_.Notify(state_);
}

Powered by Google App Engine
This is Rietveld 408576698