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

Unified Diff: chrome/browser/policy/auto_enrollment_client.h

Issue 8872032: Added the AutoEnrollmentClient and unit tests for it. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Style cleanup, rebased Created 9 years 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/policy/auto_enrollment_client.h
diff --git a/chrome/browser/policy/auto_enrollment_client.h b/chrome/browser/policy/auto_enrollment_client.h
new file mode 100644
index 0000000000000000000000000000000000000000..c9b2437bee66adbc0205c8fa4024a11d8ceeb053
--- /dev/null
+++ b/chrome/browser/policy/auto_enrollment_client.h
@@ -0,0 +1,106 @@
+// Copyright (c) 2011 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.
+
+#ifndef CHROME_BROWSER_POLICY_AUTO_ENROLLMENT_CLIENT_H_
+#define CHROME_BROWSER_POLICY_AUTO_ENROLLMENT_CLIENT_H_
+#pragma once
+
+#include <string>
+
+#include "base/basictypes.h"
+#include "base/callback.h"
+#include "base/compiler_specific.h"
+#include "base/memory/scoped_ptr.h"
+#include "chrome/browser/policy/device_management_backend.h"
+#include "third_party/protobuf/src/google/protobuf/repeated_field.h"
+
+namespace policy {
+
+class DeviceManagementService;
+
+// Interacts with the device management service and determines whether this
+// machine should automatically enter the Enterprise Enrollment screen during
+// OOBE.
+class AutoEnrollmentClient
+ : public DeviceManagementBackend::DeviceAutoEnrollmentResponseDelegate {
+ public:
+ // |completion_callback| will be invoked on completion of the protocol, after
+ // Start() is invoked.
+ // Takes ownership of |device_management_service|.
+ // |power_initial| and |power_limit| are exponents of power-of-2 values which
+ // will be the initial modulus and the maximum modulus used by this client.
+ AutoEnrollmentClient(const base::Closure& completion_callback,
+ DeviceManagementService* device_management_service,
+ const std::string& serial_number,
+ int power_initial,
+ int power_limit);
+ virtual ~AutoEnrollmentClient();
+
+ // Convenience method to create instances of this class.
+ static AutoEnrollmentClient* Create(const base::Closure& completion_callback);
+
+ // Starts the auto-enrollment check protocol with the device management
+ // service. Subsequent calls drop any previous requests. Notice that this
+ // call can invoke the |completion_callback_| if errors occur.
+ void Start();
+
+ // Returns true if the protocol completed successfully and determined that
+ // this device should do enterprise enrollment.
+ bool should_auto_enroll() const { return should_auto_enroll_; }
+
+ // Returns the device_id randomly generated for the auto-enrollment requests.
+ // It can be reused for subsequent requests to the device management service.
+ std::string device_id() const { return device_id_; }
+
+ private:
+ // Sends an auto-enrollment check request to the device management service.
+ // |power| is the power of the power-of-2 to use as a modulus for this
+ // request.
+ void SendRequest(int power);
+
+ // Implementation of DeviceAutoEnrollmentResponseDelegate:
+ virtual void HandleAutoEnrollmentResponse(
+ const em::DeviceAutoEnrollmentResponse& response) OVERRIDE;
+ virtual void OnError(DeviceManagementBackend::ErrorCode code) OVERRIDE;
+
+ // Returns true if |serial_number_hash_| is contained in |hashes|.
+ bool IsSerialInProtobuf(
+ const google::protobuf::RepeatedPtrField<std::string>& hashes);
+
+ // Callback to invoke when the protocol completes.
+ base::Closure completion_callback_;
+
+ // Whether to auto-enroll or not. This is reset by calls to Start(), and only
+ // turns true if the protocol and the serial number check succeed.
+ bool should_auto_enroll_;
+
+ // Randomly generated device id for the auto-enrollment requests.
+ std::string device_id_;
+
+ // SHA256 hash of the device's serial number. Empty if the serial couldn't be
+ // retrieved.
+ std::string serial_number_hash_;
+
+ // Power of the power-of-2 modulus used in the initial auto-enrollment
+ // request.
+ int power_initial_;
+
+ // Power of the maximum power-of-2 modulus that this client will accept from
+ // a retry response from the server.
+ int power_limit_;
+
+ // Modulus used in the last request sent to the server.
+ // Used to determine if the server is asking for the same modulus.
+ int last_power_used_;
+
+ // Used to communicate with the device management service.
+ scoped_ptr<DeviceManagementService> device_management_service_;
+ scoped_ptr<DeviceManagementBackend> device_management_backend_;
+
+ DISALLOW_COPY_AND_ASSIGN(AutoEnrollmentClient);
+};
+
+} // namespace policy
+
+#endif // CHROME_BROWSER_POLICY_AUTO_ENROLLMENT_CLIENT_H_
« no previous file with comments | « chrome/browser/automation/automation_provider_observers.cc ('k') | chrome/browser/policy/auto_enrollment_client.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698