| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/extensions/api/networking_private/networking_private_ch
romeos.h" | 5 #include "extensions/browser/api/networking_private/networking_private_chromeos.
h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "base/callback.h" | 9 #include "base/callback.h" |
| 10 #include "chrome/browser/chromeos/profiles/profile_helper.h" | |
| 11 #include "chrome/browser/extensions/api/networking_private/networking_private_ap
i.h" | |
| 12 #include "chrome/common/extensions/api/networking_private.h" | |
| 13 #include "chromeos/dbus/dbus_thread_manager.h" | 10 #include "chromeos/dbus/dbus_thread_manager.h" |
| 14 #include "chromeos/dbus/shill_manager_client.h" | 11 #include "chromeos/dbus/shill_manager_client.h" |
| 15 #include "chromeos/login/login_state.h" | 12 #include "chromeos/login/login_state.h" |
| 16 #include "chromeos/network/managed_network_configuration_handler.h" | 13 #include "chromeos/network/managed_network_configuration_handler.h" |
| 17 #include "chromeos/network/network_connection_handler.h" | 14 #include "chromeos/network/network_connection_handler.h" |
| 18 #include "chromeos/network/network_device_handler.h" | 15 #include "chromeos/network/network_device_handler.h" |
| 19 #include "chromeos/network/network_event_log.h" | 16 #include "chromeos/network/network_event_log.h" |
| 20 #include "chromeos/network/network_state.h" | 17 #include "chromeos/network/network_state.h" |
| 21 #include "chromeos/network/network_state_handler.h" | 18 #include "chromeos/network/network_state_handler.h" |
| 22 #include "chromeos/network/network_util.h" | 19 #include "chromeos/network/network_util.h" |
| 23 #include "chromeos/network/onc/onc_signature.h" | 20 #include "chromeos/network/onc/onc_signature.h" |
| 24 #include "chromeos/network/onc/onc_translator.h" | 21 #include "chromeos/network/onc/onc_translator.h" |
| 25 #include "chromeos/network/onc/onc_utils.h" | 22 #include "chromeos/network/onc/onc_utils.h" |
| 26 #include "chromeos/network/portal_detector/network_portal_detector.h" | 23 #include "chromeos/network/portal_detector/network_portal_detector.h" |
| 27 #include "components/onc/onc_constants.h" | 24 #include "components/onc/onc_constants.h" |
| 28 #include "content/public/browser/browser_context.h" | 25 #include "content/public/browser/browser_context.h" |
| 26 #include "extensions/browser/api/networking_private/networking_private_api.h" |
| 27 #include "extensions/browser/extensions_browser_client.h" |
| 28 #include "extensions/common/api/networking_private.h" |
| 29 | 29 |
| 30 using chromeos::NetworkHandler; | 30 using chromeos::NetworkHandler; |
| 31 using chromeos::NetworkTypePattern; | 31 using chromeos::NetworkTypePattern; |
| 32 using chromeos::ShillManagerClient; | 32 using chromeos::ShillManagerClient; |
| 33 using extensions::NetworkingPrivateDelegate; | 33 using extensions::NetworkingPrivateDelegate; |
| 34 | 34 |
| 35 namespace { | 35 namespace { |
| 36 | 36 |
| 37 chromeos::NetworkStateHandler* GetStateHandler() { | 37 chromeos::NetworkStateHandler* GetStateHandler() { |
| 38 return NetworkHandler::Get()->network_state_handler(); | 38 return NetworkHandler::Get()->network_state_handler(); |
| (...skipping 12 matching lines...) Expand all Loading... |
| 51 *error = extensions::networking_private::kErrorInvalidNetworkGuid; | 51 *error = extensions::networking_private::kErrorInvalidNetworkGuid; |
| 52 return false; | 52 return false; |
| 53 } | 53 } |
| 54 *service_path = network->path(); | 54 *service_path = network->path(); |
| 55 return true; | 55 return true; |
| 56 } | 56 } |
| 57 | 57 |
| 58 bool GetUserIdHash(content::BrowserContext* browser_context, | 58 bool GetUserIdHash(content::BrowserContext* browser_context, |
| 59 std::string* user_hash, | 59 std::string* user_hash, |
| 60 std::string* error) { | 60 std::string* error) { |
| 61 std::string profile_user_hash = | 61 std::string context_user_hash = |
| 62 chromeos::ProfileHelper::GetUserIdHashFromProfile( | 62 extensions::ExtensionsBrowserClient::Get()->GetUserIdHashFromContext( |
| 63 static_cast<Profile*>(browser_context)); | 63 browser_context); |
| 64 | 64 |
| 65 // Currently Chrome OS only configures networks for the primary user. | 65 // Currently Chrome OS only configures networks for the primary user. |
| 66 // Configuration attempts from other browser contexts should fail. | 66 // Configuration attempts from other browser contexts should fail. |
| 67 // TODO(stevenjb): use an ExtensionsBrowserClient method to access | 67 if (context_user_hash != chromeos::LoginState::Get()->primary_user_hash()) { |
| 68 // ProfileHelper when moving this to src/extensions. | |
| 69 if (profile_user_hash != chromeos::LoginState::Get()->primary_user_hash()) { | |
| 70 // Disallow class requiring a user id hash from a non-primary user context | 68 // Disallow class requiring a user id hash from a non-primary user context |
| 71 // to avoid complexities with the policy code. | 69 // to avoid complexities with the policy code. |
| 72 LOG(ERROR) << "networkingPrivate API call from non primary user: " | 70 LOG(ERROR) << "networkingPrivate API call from non primary user: " |
| 73 << profile_user_hash; | 71 << context_user_hash; |
| 74 *error = "Error.NonPrimaryUser"; | 72 *error = "Error.NonPrimaryUser"; |
| 75 return false; | 73 return false; |
| 76 } | 74 } |
| 77 *user_hash = profile_user_hash; | 75 *user_hash = context_user_hash; |
| 78 return true; | 76 return true; |
| 79 } | 77 } |
| 80 | 78 |
| 81 void NetworkHandlerDictionaryCallback( | 79 void NetworkHandlerDictionaryCallback( |
| 82 const NetworkingPrivateDelegate::DictionaryCallback& callback, | 80 const NetworkingPrivateDelegate::DictionaryCallback& callback, |
| 83 const std::string& service_path, | 81 const std::string& service_path, |
| 84 const base::DictionaryValue& dictionary) { | 82 const base::DictionaryValue& dictionary) { |
| 85 scoped_ptr<base::DictionaryValue> dictionary_copy(dictionary.DeepCopy()); | 83 scoped_ptr<base::DictionaryValue> dictionary_copy(dictionary.DeepCopy()); |
| 86 callback.Run(dictionary_copy.Pass()); | 84 callback.Run(dictionary_copy.Pass()); |
| 87 } | 85 } |
| (...skipping 11 matching lines...) Expand all Loading... |
| 99 | 97 |
| 100 namespace extensions { | 98 namespace extensions { |
| 101 | 99 |
| 102 NetworkingPrivateChromeOS::NetworkingPrivateChromeOS( | 100 NetworkingPrivateChromeOS::NetworkingPrivateChromeOS( |
| 103 content::BrowserContext* browser_context, | 101 content::BrowserContext* browser_context, |
| 104 scoped_ptr<VerifyDelegate> verify_delegate) | 102 scoped_ptr<VerifyDelegate> verify_delegate) |
| 105 : NetworkingPrivateDelegate(verify_delegate.Pass()), | 103 : NetworkingPrivateDelegate(verify_delegate.Pass()), |
| 106 browser_context_(browser_context) { | 104 browser_context_(browser_context) { |
| 107 } | 105 } |
| 108 | 106 |
| 109 NetworkingPrivateChromeOS::~NetworkingPrivateChromeOS() {} | 107 NetworkingPrivateChromeOS::~NetworkingPrivateChromeOS() { |
| 108 } |
| 110 | 109 |
| 111 void NetworkingPrivateChromeOS::GetProperties( | 110 void NetworkingPrivateChromeOS::GetProperties( |
| 112 const std::string& guid, | 111 const std::string& guid, |
| 113 const DictionaryCallback& success_callback, | 112 const DictionaryCallback& success_callback, |
| 114 const FailureCallback& failure_callback) { | 113 const FailureCallback& failure_callback) { |
| 115 std::string service_path, error; | 114 std::string service_path, error; |
| 116 if (!GetServicePathFromGuid(guid, &service_path, &error)) { | 115 if (!GetServicePathFromGuid(guid, &service_path, &error)) { |
| 117 failure_callback.Run(error); | 116 failure_callback.Run(error); |
| 118 return; | 117 return; |
| 119 } | 118 } |
| (...skipping 14 matching lines...) Expand all Loading... |
| 134 return; | 133 return; |
| 135 } | 134 } |
| 136 | 135 |
| 137 std::string user_id_hash; | 136 std::string user_id_hash; |
| 138 if (!GetUserIdHash(browser_context_, &user_id_hash, &error)) { | 137 if (!GetUserIdHash(browser_context_, &user_id_hash, &error)) { |
| 139 failure_callback.Run(error); | 138 failure_callback.Run(error); |
| 140 return; | 139 return; |
| 141 } | 140 } |
| 142 | 141 |
| 143 GetManagedConfigurationHandler()->GetManagedProperties( | 142 GetManagedConfigurationHandler()->GetManagedProperties( |
| 144 user_id_hash, | 143 user_id_hash, service_path, |
| 145 service_path, | |
| 146 base::Bind(&NetworkHandlerDictionaryCallback, success_callback), | 144 base::Bind(&NetworkHandlerDictionaryCallback, success_callback), |
| 147 base::Bind(&NetworkHandlerFailureCallback, failure_callback)); | 145 base::Bind(&NetworkHandlerFailureCallback, failure_callback)); |
| 148 } | 146 } |
| 149 | 147 |
| 150 void NetworkingPrivateChromeOS::GetState( | 148 void NetworkingPrivateChromeOS::GetState( |
| 151 const std::string& guid, | 149 const std::string& guid, |
| 152 const DictionaryCallback& success_callback, | 150 const DictionaryCallback& success_callback, |
| 153 const FailureCallback& failure_callback) { | 151 const FailureCallback& failure_callback) { |
| 154 std::string service_path, error; | 152 std::string service_path, error; |
| 155 if (!GetServicePathFromGuid(guid, &service_path, &error)) { | 153 if (!GetServicePathFromGuid(guid, &service_path, &error)) { |
| (...skipping 20 matching lines...) Expand all Loading... |
| 176 scoped_ptr<base::DictionaryValue> properties, | 174 scoped_ptr<base::DictionaryValue> properties, |
| 177 const VoidCallback& success_callback, | 175 const VoidCallback& success_callback, |
| 178 const FailureCallback& failure_callback) { | 176 const FailureCallback& failure_callback) { |
| 179 std::string service_path, error; | 177 std::string service_path, error; |
| 180 if (!GetServicePathFromGuid(guid, &service_path, &error)) { | 178 if (!GetServicePathFromGuid(guid, &service_path, &error)) { |
| 181 failure_callback.Run(error); | 179 failure_callback.Run(error); |
| 182 return; | 180 return; |
| 183 } | 181 } |
| 184 | 182 |
| 185 GetManagedConfigurationHandler()->SetProperties( | 183 GetManagedConfigurationHandler()->SetProperties( |
| 186 service_path, | 184 service_path, *properties, success_callback, |
| 187 *properties, | |
| 188 success_callback, | |
| 189 base::Bind(&NetworkHandlerFailureCallback, failure_callback)); | 185 base::Bind(&NetworkHandlerFailureCallback, failure_callback)); |
| 190 } | 186 } |
| 191 | 187 |
| 192 void NetworkingPrivateChromeOS::CreateNetwork( | 188 void NetworkingPrivateChromeOS::CreateNetwork( |
| 193 bool shared, | 189 bool shared, |
| 194 scoped_ptr<base::DictionaryValue> properties, | 190 scoped_ptr<base::DictionaryValue> properties, |
| 195 const StringCallback& success_callback, | 191 const StringCallback& success_callback, |
| 196 const FailureCallback& failure_callback) { | 192 const FailureCallback& failure_callback) { |
| 197 std::string user_id_hash, error; | 193 std::string user_id_hash, error; |
| 198 // Do not allow configuring a non-shared network from a non-primary user. | 194 // Do not allow configuring a non-shared network from a non-primary user. |
| 199 if (!shared && !GetUserIdHash(browser_context_, &user_id_hash, &error)) { | 195 if (!shared && !GetUserIdHash(browser_context_, &user_id_hash, &error)) { |
| 200 failure_callback.Run(error); | 196 failure_callback.Run(error); |
| 201 return; | 197 return; |
| 202 } | 198 } |
| 203 | 199 |
| 204 GetManagedConfigurationHandler()->CreateConfiguration( | 200 GetManagedConfigurationHandler()->CreateConfiguration( |
| 205 user_id_hash, | 201 user_id_hash, *properties, success_callback, |
| 206 *properties, | |
| 207 success_callback, | |
| 208 base::Bind(&NetworkHandlerFailureCallback, failure_callback)); | 202 base::Bind(&NetworkHandlerFailureCallback, failure_callback)); |
| 209 } | 203 } |
| 210 | 204 |
| 211 void NetworkingPrivateChromeOS::GetNetworks( | 205 void NetworkingPrivateChromeOS::GetNetworks( |
| 212 const std::string& network_type, | 206 const std::string& network_type, |
| 213 bool configured_only, | 207 bool configured_only, |
| 214 bool visible_only, | 208 bool visible_only, |
| 215 int limit, | 209 int limit, |
| 216 const NetworkListCallback& success_callback, | 210 const NetworkListCallback& success_callback, |
| 217 const FailureCallback& failure_callback) { | 211 const FailureCallback& failure_callback) { |
| (...skipping 10 matching lines...) Expand all Loading... |
| 228 const VoidCallback& success_callback, | 222 const VoidCallback& success_callback, |
| 229 const FailureCallback& failure_callback) { | 223 const FailureCallback& failure_callback) { |
| 230 std::string service_path, error; | 224 std::string service_path, error; |
| 231 if (!GetServicePathFromGuid(guid, &service_path, &error)) { | 225 if (!GetServicePathFromGuid(guid, &service_path, &error)) { |
| 232 failure_callback.Run(error); | 226 failure_callback.Run(error); |
| 233 return; | 227 return; |
| 234 } | 228 } |
| 235 | 229 |
| 236 const bool check_error_state = false; | 230 const bool check_error_state = false; |
| 237 NetworkHandler::Get()->network_connection_handler()->ConnectToNetwork( | 231 NetworkHandler::Get()->network_connection_handler()->ConnectToNetwork( |
| 238 service_path, | 232 service_path, success_callback, |
| 239 success_callback, | |
| 240 base::Bind(&NetworkHandlerFailureCallback, failure_callback), | 233 base::Bind(&NetworkHandlerFailureCallback, failure_callback), |
| 241 check_error_state); | 234 check_error_state); |
| 242 } | 235 } |
| 243 | 236 |
| 244 void NetworkingPrivateChromeOS::StartDisconnect( | 237 void NetworkingPrivateChromeOS::StartDisconnect( |
| 245 const std::string& guid, | 238 const std::string& guid, |
| 246 const VoidCallback& success_callback, | 239 const VoidCallback& success_callback, |
| 247 const FailureCallback& failure_callback) { | 240 const FailureCallback& failure_callback) { |
| 248 std::string service_path, error; | 241 std::string service_path, error; |
| 249 if (!GetServicePathFromGuid(guid, &service_path, &error)) { | 242 if (!GetServicePathFromGuid(guid, &service_path, &error)) { |
| 250 failure_callback.Run(error); | 243 failure_callback.Run(error); |
| 251 return; | 244 return; |
| 252 } | 245 } |
| 253 | 246 |
| 254 NetworkHandler::Get()->network_connection_handler()->DisconnectNetwork( | 247 NetworkHandler::Get()->network_connection_handler()->DisconnectNetwork( |
| 255 service_path, | 248 service_path, success_callback, |
| 256 success_callback, | |
| 257 base::Bind(&NetworkHandlerFailureCallback, failure_callback)); | 249 base::Bind(&NetworkHandlerFailureCallback, failure_callback)); |
| 258 } | 250 } |
| 259 | 251 |
| 260 void NetworkingPrivateChromeOS::SetWifiTDLSEnabledState( | 252 void NetworkingPrivateChromeOS::SetWifiTDLSEnabledState( |
| 261 const std::string& ip_or_mac_address, | 253 const std::string& ip_or_mac_address, |
| 262 bool enabled, | 254 bool enabled, |
| 263 const StringCallback& success_callback, | 255 const StringCallback& success_callback, |
| 264 const FailureCallback& failure_callback) { | 256 const FailureCallback& failure_callback) { |
| 265 NetworkHandler::Get()->network_device_handler()->SetWifiTDLSEnabled( | 257 NetworkHandler::Get()->network_device_handler()->SetWifiTDLSEnabled( |
| 266 ip_or_mac_address, | 258 ip_or_mac_address, enabled, success_callback, |
| 267 enabled, | |
| 268 success_callback, | |
| 269 base::Bind(&NetworkHandlerFailureCallback, failure_callback)); | 259 base::Bind(&NetworkHandlerFailureCallback, failure_callback)); |
| 270 } | 260 } |
| 271 | 261 |
| 272 void NetworkingPrivateChromeOS::GetWifiTDLSStatus( | 262 void NetworkingPrivateChromeOS::GetWifiTDLSStatus( |
| 273 const std::string& ip_or_mac_address, | 263 const std::string& ip_or_mac_address, |
| 274 const StringCallback& success_callback, | 264 const StringCallback& success_callback, |
| 275 const FailureCallback& failure_callback) { | 265 const FailureCallback& failure_callback) { |
| 276 NetworkHandler::Get()->network_device_handler()->GetWifiTDLSStatus( | 266 NetworkHandler::Get()->network_device_handler()->GetWifiTDLSStatus( |
| 277 ip_or_mac_address, | 267 ip_or_mac_address, success_callback, |
| 278 success_callback, | |
| 279 base::Bind(&NetworkHandlerFailureCallback, failure_callback)); | 268 base::Bind(&NetworkHandlerFailureCallback, failure_callback)); |
| 280 } | 269 } |
| 281 | 270 |
| 282 void NetworkingPrivateChromeOS::GetCaptivePortalStatus( | 271 void NetworkingPrivateChromeOS::GetCaptivePortalStatus( |
| 283 const std::string& guid, | 272 const std::string& guid, |
| 284 const StringCallback& success_callback, | 273 const StringCallback& success_callback, |
| 285 const FailureCallback& failure_callback) { | 274 const FailureCallback& failure_callback) { |
| 286 if (!chromeos::NetworkPortalDetector::IsInitialized()) { | 275 if (!chromeos::NetworkPortalDetector::IsInitialized()) { |
| 287 failure_callback.Run(networking_private::kErrorNotReady); | 276 failure_callback.Run(networking_private::kErrorNotReady); |
| 288 return; | 277 return; |
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 331 | 320 |
| 332 return true; | 321 return true; |
| 333 } | 322 } |
| 334 | 323 |
| 335 bool NetworkingPrivateChromeOS::RequestScan() { | 324 bool NetworkingPrivateChromeOS::RequestScan() { |
| 336 GetStateHandler()->RequestScan(); | 325 GetStateHandler()->RequestScan(); |
| 337 return true; | 326 return true; |
| 338 } | 327 } |
| 339 | 328 |
| 340 } // namespace extensions | 329 } // namespace extensions |
| OLD | NEW |