1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CHROME_BROWSER_CHROMEOS_POLICY_DEVICE_CLOUD_POLICY_MANAGER_CHROMEOS_H_
6 #define CHROME_BROWSER_CHROMEOS_POLICY_DEVICE_CLOUD_POLICY_MANAGER_CHROMEOS_H_
11 #include "base/basictypes.h"
12 #include "base/callback_forward.h"
13 #include "base/compiler_specific.h"
14 #include "base/memory/ref_counted.h"
15 #include "base/memory/scoped_ptr.h"
16 #include "base/observer_list.h"
17 #include "chrome/browser/chromeos/policy/server_backed_state_keys_broker.h"
18 #include "components/policy/core/common/cloud/cloud_policy_client.h"
19 #include "components/policy/core/common/cloud/cloud_policy_manager.h"
22 class SequencedTaskRunner
;
26 namespace attestation
{
27 class AttestationPolicyObserver
;
31 class PrefRegistrySimple
;
36 class DeviceCloudPolicyStoreChromeOS
;
37 class EnterpriseInstallAttributes
;
38 class HeartbeatScheduler
;
41 // CloudPolicyManager specialization for device policy on Chrome OS.
42 class DeviceCloudPolicyManagerChromeOS
: public CloudPolicyManager
{
46 // Invoked when the device cloud policy manager connects.
47 virtual void OnDeviceCloudPolicyManagerConnected() = 0;
48 // Invoked when the device cloud policy manager disconnects.
49 virtual void OnDeviceCloudPolicyManagerDisconnected() = 0;
52 using UnregisterCallback
= base::Callback
<void(bool)>;
54 // |task_runner| is the runner for policy refresh, heartbeat, and status
56 DeviceCloudPolicyManagerChromeOS(
57 scoped_ptr
<DeviceCloudPolicyStoreChromeOS
> store
,
58 const scoped_refptr
<base::SequencedTaskRunner
>& task_runner
,
59 ServerBackedStateKeysBroker
* state_keys_broker
);
60 ~DeviceCloudPolicyManagerChromeOS() override
;
62 // Initializes state keys and requisition information.
63 void Initialize(PrefService
* local_state
);
65 void AddDeviceCloudPolicyManagerObserver(Observer
* observer
);
66 void RemoveDeviceCloudPolicyManagerObserver(Observer
* observer
);
68 // TODO(davidyu): Move these two functions to a more appropriate place. See
69 // http://crbug.com/383695.
70 // Gets/Sets the device requisition.
71 std::string
GetDeviceRequisition() const;
72 void SetDeviceRequisition(const std::string
& requisition
);
73 bool IsRemoraRequisition() const;
74 bool IsSharkRequisition() const;
76 // CloudPolicyManager:
77 void Shutdown() override
;
79 // Pref registration helper.
80 static void RegisterPrefs(PrefRegistrySimple
* registry
);
82 // Returns the device serial number, or an empty string if not available.
83 static std::string
GetMachineID();
85 // Returns the machine model, or an empty string if not available.
86 static std::string
GetMachineModel();
88 // Returns the robot 'email address' associated with the device robot
89 // account (sometimes called a service account) associated with this device
90 // during enterprise enrollment.
91 std::string
GetRobotAccountId();
93 // Starts the connection via |client_to_connect|.
94 void StartConnection(scoped_ptr
<CloudPolicyClient
> client_to_connect
,
95 EnterpriseInstallAttributes
* install_attributes
);
97 // Sends the unregister request. |callback| is invoked with a boolean
98 // parameter indicating the result when done.
99 virtual void Unregister(const UnregisterCallback
& callback
);
101 // Disconnects the manager.
102 virtual void Disconnect();
104 DeviceCloudPolicyStoreChromeOS
* device_store() {
105 return device_store_
.get();
108 // Return the StatusUploader used to communicate device status to the
110 StatusUploader
* GetStatusUploader() const { return status_uploader_
.get(); }
113 // Saves the state keys received from |session_manager_client_|.
114 void OnStateKeysUpdated();
116 // Initializes requisition settings at OOBE with values from VPD.
117 void InitializeRequisition();
119 void NotifyConnected();
120 void NotifyDisconnected();
122 // Factory function to create the StatusUploader.
123 void CreateStatusUploader();
125 // Points to the same object as the base CloudPolicyManager::store(), but with
126 // actual device policy specific type.
127 scoped_ptr
<DeviceCloudPolicyStoreChromeOS
> device_store_
;
128 ServerBackedStateKeysBroker
* state_keys_broker_
;
130 // Helper object that handles updating the server with our current device
132 scoped_ptr
<StatusUploader
> status_uploader_
;
134 // Helper object that handles sending heartbeats over the GCM channel to
135 // the server, to monitor connectivity.
136 scoped_ptr
<HeartbeatScheduler
> heartbeat_scheduler_
;
138 // The TaskRunner used to do device status uploads.
139 scoped_refptr
<base::SequencedTaskRunner
> task_runner_
;
141 ServerBackedStateKeysBroker::Subscription state_keys_update_subscription_
;
143 // PrefService instance to read the policy refresh rate from.
144 PrefService
* local_state_
;
146 scoped_ptr
<chromeos::attestation::AttestationPolicyObserver
>
147 attestation_policy_observer_
;
149 base::ObserverList
<Observer
, true> observers_
;
151 DISALLOW_COPY_AND_ASSIGN(DeviceCloudPolicyManagerChromeOS
);
154 } // namespace policy
156 #endif // CHROME_BROWSER_CHROMEOS_POLICY_DEVICE_CLOUD_POLICY_MANAGER_CHROMEOS_H_