Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/policy/device_policy_identity_strategy.h" | 5 #include "chrome/browser/policy/device_policy_identity_strategy.h" |
| 6 | 6 |
| 7 #include "chrome/browser/browser_process.h" | 7 #include "chrome/browser/browser_process.h" |
| 8 #include "chrome/browser/chromeos/login/ownership_service.h" | 8 #include "chrome/browser/chromeos/login/ownership_service.h" |
| 9 #include "chrome/browser/chromeos/login/user_manager.h" | 9 #include "chrome/browser/chromeos/login/user_manager.h" |
| 10 #include "chrome/browser/net/gaia/token_service.h" | 10 #include "chrome/browser/net/gaia/token_service.h" |
| 11 #include "chrome/browser/policy/proto/device_management_constants.h" | |
| 11 #include "chrome/browser/profiles/profile.h" | 12 #include "chrome/browser/profiles/profile.h" |
| 12 #include "chrome/browser/profiles/profile_manager.h" | 13 #include "chrome/browser/profiles/profile_manager.h" |
| 14 #include "chrome/common/guid.h" | |
| 13 #include "chrome/common/net/gaia/gaia_constants.h" | 15 #include "chrome/common/net/gaia/gaia_constants.h" |
| 14 #include "chrome/common/notification_service.h" | 16 #include "chrome/common/notification_service.h" |
| 15 #include "chrome/common/notification_type.h" | 17 #include "chrome/common/notification_type.h" |
| 16 | 18 |
| 19 #if defined(OS_CHROMEOS) | |
|
Mattias Nissler (ping if slow)
2011/02/21 14:55:27
Not needed, this file is on compiled on CrOS
gfeher
2011/02/22 15:57:29
Done.
| |
| 20 #include "chrome/browser/chromeos/cros/cros_library.h" | |
| 21 #include "chrome/browser/chromeos/cros/system_library.h" | |
| 22 #endif | |
| 23 | |
| 17 namespace policy { | 24 namespace policy { |
| 18 | 25 |
| 26 namespace { | |
| 27 // Key name for MachineInfo. | |
| 28 const char kMachineInfoSerialNumber[] = "serial_number"; | |
| 29 } | |
| 30 | |
| 19 DevicePolicyIdentityStrategy::DevicePolicyIdentityStrategy() | 31 DevicePolicyIdentityStrategy::DevicePolicyIdentityStrategy() |
| 20 : should_register_(false) { | 32 : should_register_(false) { |
| 21 registrar_.Add(this, | 33 registrar_.Add(this, |
| 22 NotificationType::TOKEN_AVAILABLE, | 34 NotificationType::TOKEN_AVAILABLE, |
| 23 NotificationService::AllSources()); | 35 NotificationService::AllSources()); |
| 24 registrar_.Add(this, | 36 registrar_.Add(this, |
| 25 NotificationType::LOGIN_USER_CHANGED, | 37 NotificationType::LOGIN_USER_CHANGED, |
| 26 NotificationService::AllSources()); | 38 NotificationService::AllSources()); |
| 27 registrar_.Add(this, | 39 registrar_.Add(this, |
| 28 NotificationType::OWNERSHIP_TAKEN, | 40 NotificationType::OWNERSHIP_TAKEN, |
| 29 NotificationService::AllSources()); | 41 NotificationService::AllSources()); |
| 30 registrar_.Add(this, | 42 registrar_.Add(this, |
| 31 NotificationType::OWNER_KEY_FETCH_ATTEMPT_SUCCEEDED, | 43 NotificationType::OWNER_KEY_FETCH_ATTEMPT_SUCCEEDED, |
| 32 NotificationService::AllSources()); | 44 NotificationService::AllSources()); |
| 33 | 45 |
| 34 // TODO(mnissler): Figure out how to read the machine id. | 46 machine_id_ = "unknown-cros-machine-ID"; |
| 35 machine_id_ = "dummy-cros-machine-ID"; | 47 #if defined(OS_CHROMEOS) |
| 48 chromeos::SystemLibrary* sys_lib = | |
| 49 chromeos::CrosLibrary::Get()->GetSystemLibrary(); | |
|
Mattias Nissler (ping if slow)
2011/02/21 14:55:27
Nice!
But I've heard rumors about the serial numb
gfeher
2011/02/22 15:57:29
I am still fighting with ChromeOS build to make a
| |
| 50 | |
| 51 // Required info. | |
| 52 std::string serial_number; | |
| 53 if (!sys_lib->GetMachineStatistic(kMachineInfoSerialNumber, &machine_id_)) { | |
| 54 LOG(WARNING) << "Failed to get machine serial number." << std::endl; | |
| 55 } | |
| 56 #endif | |
| 36 } | 57 } |
| 37 | 58 |
| 38 std::string DevicePolicyIdentityStrategy::GetDeviceToken() { | 59 std::string DevicePolicyIdentityStrategy::GetDeviceToken() { |
| 39 return device_token_; | 60 return device_token_; |
| 40 } | 61 } |
| 41 | 62 |
| 42 std::string DevicePolicyIdentityStrategy::GetDeviceID() { | 63 std::string DevicePolicyIdentityStrategy::GetDeviceID() { |
| 43 return machine_id_; | 64 return machine_id_; |
|
Jakob Kummerow
2011/02/21 16:15:00
s/machine_id_/device_id_/ ?
gfeher
2011/02/22 15:57:29
Whoops!
| |
| 44 } | 65 } |
| 45 | 66 |
| 67 std::string DevicePolicyIdentityStrategy::GetMachineID() { | |
| 68 return machine_id_; | |
| 69 } | |
| 70 | |
| 71 em::DeviceRegisterRequest_Type | |
| 72 DevicePolicyIdentityStrategy::GetPolicyRegisterType() { | |
| 73 return em::DeviceRegisterRequest::DEVICE; | |
| 74 } | |
| 75 | |
| 76 std::string DevicePolicyIdentityStrategy::GetPolicyType() { | |
| 77 return kChromeDevicePolicyType; | |
| 78 } | |
| 79 | |
| 46 bool DevicePolicyIdentityStrategy::GetCredentials(std::string* username, | 80 bool DevicePolicyIdentityStrategy::GetCredentials(std::string* username, |
| 47 std::string* auth_token) { | 81 std::string* auth_token) { |
| 48 // Only register if requested. | 82 // Only register if requested. |
| 49 if (!should_register_) | 83 if (!should_register_) |
| 50 return false; | 84 return false; |
| 51 | 85 |
| 52 // Need to know the machine id. | 86 // Need to know the machine id. |
| 53 if (machine_id_.empty()) | 87 if (machine_id_.empty()) |
| 54 return false; | 88 return false; |
| 55 | 89 |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 79 // Reset registration flag, so we only attempt registration once. | 113 // Reset registration flag, so we only attempt registration once. |
| 80 should_register_ = false; | 114 should_register_ = false; |
| 81 | 115 |
| 82 device_token_ = token; | 116 device_token_ = token; |
| 83 NotifyDeviceTokenChanged(); | 117 NotifyDeviceTokenChanged(); |
| 84 } | 118 } |
| 85 | 119 |
| 86 void DevicePolicyIdentityStrategy::CheckAndTriggerFetch() { | 120 void DevicePolicyIdentityStrategy::CheckAndTriggerFetch() { |
| 87 std::string username; | 121 std::string username; |
| 88 std::string auth_token; | 122 std::string auth_token; |
| 89 if (GetCredentials(&username, &auth_token)) | 123 if (GetCredentials(&username, &auth_token)) { |
| 124 device_id_ = guid::GenerateGUID(); | |
| 90 NotifyAuthChanged(); | 125 NotifyAuthChanged(); |
| 126 } | |
| 91 } | 127 } |
| 92 | 128 |
| 93 void DevicePolicyIdentityStrategy::Observe(NotificationType type, | 129 void DevicePolicyIdentityStrategy::Observe(NotificationType type, |
| 94 const NotificationSource& source, | 130 const NotificationSource& source, |
| 95 const NotificationDetails& details) { | 131 const NotificationDetails& details) { |
| 96 if (type == NotificationType::TOKEN_AVAILABLE) { | 132 if (type == NotificationType::TOKEN_AVAILABLE) { |
| 97 const TokenService::TokenAvailableDetails* token_details = | 133 const TokenService::TokenAvailableDetails* token_details = |
| 98 Details<const TokenService::TokenAvailableDetails>(details).ptr(); | 134 Details<const TokenService::TokenAvailableDetails>(details).ptr(); |
| 99 if (token_details->service() == GaiaConstants::kDeviceManagementService) | 135 if (token_details->service() == GaiaConstants::kDeviceManagementService) |
| 100 CheckAndTriggerFetch(); | 136 CheckAndTriggerFetch(); |
| 101 } else if (type == NotificationType::LOGIN_USER_CHANGED) { | 137 } else if (type == NotificationType::LOGIN_USER_CHANGED) { |
| 102 should_register_ = false; | 138 should_register_ = false; |
| 103 CheckAndTriggerFetch(); | 139 CheckAndTriggerFetch(); |
| 104 } else if (type == NotificationType::OWNERSHIP_TAKEN) { | 140 } else if (type == NotificationType::OWNERSHIP_TAKEN) { |
| 105 should_register_ = true; | 141 should_register_ = true; |
| 106 CheckAndTriggerFetch(); | 142 CheckAndTriggerFetch(); |
| 107 } else if (type == NotificationType::OWNER_KEY_FETCH_ATTEMPT_SUCCEEDED) { | 143 } else if (type == NotificationType::OWNER_KEY_FETCH_ATTEMPT_SUCCEEDED) { |
| 108 CheckAndTriggerFetch(); | 144 CheckAndTriggerFetch(); |
| 109 } else { | 145 } else { |
| 110 NOTREACHED(); | 146 NOTREACHED(); |
| 111 } | 147 } |
| 112 } | 148 } |
| 113 | 149 |
| 114 } // namespace policy | 150 } // namespace policy |
| OLD | NEW |