Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "components/arc/net/arc_net_host_impl.h" | 5 #include "components/arc/net/arc_net_host_impl.h" |
| 6 | 6 |
| 7 #include <memory> | 7 #include <memory> |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 22 #include "chromeos/network/network_state_handler.h" | 22 #include "chromeos/network/network_state_handler.h" |
| 23 #include "chromeos/network/network_type_pattern.h" | 23 #include "chromeos/network/network_type_pattern.h" |
| 24 #include "chromeos/network/network_util.h" | 24 #include "chromeos/network/network_util.h" |
| 25 #include "chromeos/network/onc/onc_utils.h" | 25 #include "chromeos/network/onc/onc_utils.h" |
| 26 #include "components/arc/arc_bridge_service.h" | 26 #include "components/arc/arc_bridge_service.h" |
| 27 | 27 |
| 28 namespace { | 28 namespace { |
| 29 | 29 |
| 30 const int kGetNetworksListLimit = 100; | 30 const int kGetNetworksListLimit = 100; |
| 31 | 31 |
| 32 } // namespace | |
| 33 | |
| 34 namespace arc { | |
| 35 | |
| 36 chromeos::NetworkStateHandler* GetStateHandler() { | 32 chromeos::NetworkStateHandler* GetStateHandler() { |
| 37 return chromeos::NetworkHandler::Get()->network_state_handler(); | 33 return chromeos::NetworkHandler::Get()->network_state_handler(); |
| 38 } | 34 } |
| 39 | 35 |
| 40 chromeos::ManagedNetworkConfigurationHandler* GetManagedConfigurationHandler() { | 36 chromeos::ManagedNetworkConfigurationHandler* GetManagedConfigurationHandler() { |
| 41 return chromeos::NetworkHandler::Get() | 37 return chromeos::NetworkHandler::Get() |
| 42 ->managed_network_configuration_handler(); | 38 ->managed_network_configuration_handler(); |
| 43 } | 39 } |
| 44 | 40 |
| 45 chromeos::NetworkConnectionHandler* GetNetworkConnectionHandler() { | 41 chromeos::NetworkConnectionHandler* GetNetworkConnectionHandler() { |
| 46 return chromeos::NetworkHandler::Get()->network_connection_handler(); | 42 return chromeos::NetworkHandler::Get()->network_connection_handler(); |
| 47 } | 43 } |
| 48 | 44 |
| 49 bool IsDeviceOwner() { | 45 bool IsDeviceOwner() { |
| 50 // Check whether the logged-in Chrome OS user is allowed to add or | 46 // Check whether the logged-in Chrome OS user is allowed to add or |
| 51 // remove WiFi networks. | 47 // remove WiFi networks. |
| 52 return chromeos::LoginState::Get()->GetLoggedInUserType() == | 48 return chromeos::LoginState::Get()->GetLoggedInUserType() == |
| 53 chromeos::LoginState::LOGGED_IN_USER_OWNER; | 49 chromeos::LoginState::LOGGED_IN_USER_OWNER; |
| 54 } | 50 } |
| 55 | 51 |
| 52 std::string GetStringFromOncDictionary(const base::DictionaryValue* dict, | |
| 53 const char* key, | |
| 54 bool required) { | |
| 55 std::string value; | |
| 56 dict->GetString(key, &value); | |
| 57 if (required && value.empty()) | |
| 58 NOTREACHED(); | |
| 59 return value; | |
| 60 } | |
| 61 | |
| 62 arc::mojom::SecurityType TranslateONCWifiSecurityType( | |
| 63 const base::DictionaryValue* dict) { | |
| 64 std::string type = GetStringFromOncDictionary(dict, onc::wifi::kSecurity, | |
| 65 true /* required */); | |
| 66 if (type == onc::wifi::kWEP_PSK) | |
| 67 return arc::mojom::SecurityType::WEP_PSK; | |
| 68 else if (type == onc::wifi::kWEP_8021X) | |
| 69 return arc::mojom::SecurityType::WEP_8021X; | |
| 70 else if (type == onc::wifi::kWPA_PSK) | |
| 71 return arc::mojom::SecurityType::WPA_PSK; | |
| 72 else if (type == onc::wifi::kWPA_EAP) | |
| 73 return arc::mojom::SecurityType::WPA_EAP; | |
| 74 else | |
| 75 return arc::mojom::SecurityType::NONE; | |
| 76 } | |
| 77 | |
| 78 arc::mojom::WiFiPtr TranslateONCWifi(const base::DictionaryValue* dict) { | |
| 79 arc::mojom::WiFiPtr wifi = arc::mojom::WiFi::New(); | |
| 80 | |
| 81 // Optional; defaults to 0. | |
| 82 dict->GetInteger(onc::wifi::kFrequency, &wifi->frequency); | |
| 83 | |
| 84 wifi->bssid = | |
| 85 GetStringFromOncDictionary(dict, onc::wifi::kBSSID, false /* required */); | |
| 86 wifi->hex_ssid = GetStringFromOncDictionary(dict, onc::wifi::kHexSSID, | |
| 87 true /* required */); | |
| 88 | |
| 89 // Optional; defaults to false. | |
| 90 dict->GetBoolean(onc::wifi::kHiddenSSID, &wifi->hidden_ssid); | |
| 91 | |
| 92 wifi->security = TranslateONCWifiSecurityType(dict); | |
| 93 | |
| 94 // Optional; defaults to 0. | |
| 95 dict->GetInteger(onc::wifi::kSignalStrength, &wifi->signal_strength); | |
| 96 | |
| 97 return wifi; | |
| 98 } | |
| 99 | |
| 100 mojo::Array<mojo::String> TranslateStringArray(const base::ListValue* list) { | |
| 101 mojo::Array<mojo::String> strings = mojo::Array<mojo::String>::New(0); | |
| 102 | |
| 103 for (size_t i = 0; i < list->GetSize(); i++) { | |
| 104 std::string value; | |
| 105 list->GetString(i, &value); | |
| 106 DCHECK(!value.empty()); | |
| 107 strings.push_back(static_cast<mojo::String>(value)); | |
| 108 } | |
| 109 | |
| 110 return strings; | |
| 111 } | |
| 112 | |
| 113 mojo::Array<arc::mojom::IPConfigurationPtr> TranslateONCIPConfigs( | |
| 114 const base::ListValue* list) { | |
| 115 mojo::Array<arc::mojom::IPConfigurationPtr> configs = | |
| 116 mojo::Array<arc::mojom::IPConfigurationPtr>::New(0); | |
| 117 | |
| 118 for (size_t i = 0; i < list->GetSize(); i++) { | |
| 119 const base::DictionaryValue* ip_dict = nullptr; | |
| 120 arc::mojom::IPConfigurationPtr configuration = | |
| 121 arc::mojom::IPConfiguration::New(); | |
| 122 | |
| 123 list->GetDictionary(i, &ip_dict); | |
| 124 DCHECK(ip_dict); | |
| 125 | |
| 126 configuration->gateway = GetStringFromOncDictionary( | |
| 127 ip_dict, onc::ipconfig::kGateway, true /* required */); | |
| 128 configuration->ip_address = GetStringFromOncDictionary( | |
| 129 ip_dict, onc::ipconfig::kIPAddress, true /* required */); | |
| 130 | |
| 131 const base::ListValue* dns_list; | |
| 132 if (!ip_dict->GetList(onc::ipconfig::kNameServers, &dns_list)) | |
| 133 NOTREACHED(); | |
| 134 configuration->name_servers = TranslateStringArray(dns_list); | |
| 135 | |
| 136 if (!ip_dict->GetInteger(onc::ipconfig::kRoutingPrefix, | |
| 137 &configuration->routing_prefix)) { | |
| 138 NOTREACHED(); | |
| 139 } | |
| 140 | |
| 141 std::string type = GetStringFromOncDictionary(ip_dict, onc::ipconfig::kType, | |
| 142 true /* required */); | |
| 143 configuration->type = type == onc::ipconfig::kIPv6 | |
| 144 ? arc::mojom::IPAddressType::IPV6 | |
| 145 : arc::mojom::IPAddressType::IPV4; | |
| 146 | |
| 147 configuration->web_proxy_auto_discovery_url = GetStringFromOncDictionary( | |
| 148 ip_dict, onc::ipconfig::kWebProxyAutoDiscoveryUrl, true /* required */); | |
| 149 | |
| 150 configs.push_back(std::move(configuration)); | |
| 151 } | |
| 152 return configs; | |
| 153 } | |
| 154 | |
| 155 arc::mojom::ConnectionStateType TranslateONCConnectionState( | |
| 156 const base::DictionaryValue* dict) { | |
| 157 std::string connection_state = GetStringFromOncDictionary( | |
| 158 dict, onc::network_config::kConnectionState, true /* required */); | |
| 159 | |
| 160 if (connection_state == onc::connection_state::kConnected) | |
| 161 return arc::mojom::ConnectionStateType::CONNECTED; | |
| 162 else if (connection_state == onc::connection_state::kConnecting) | |
| 163 return arc::mojom::ConnectionStateType::CONNECTING; | |
| 164 else if (connection_state == onc::connection_state::kNotConnected) | |
| 165 return arc::mojom::ConnectionStateType::NOT_CONNECTED; | |
| 166 | |
| 167 NOTREACHED(); | |
| 168 return arc::mojom::ConnectionStateType::NOT_CONNECTED; | |
| 169 } | |
| 170 | |
| 171 void TranslateONCNetworkTypeDetails(const base::DictionaryValue* dict, | |
| 172 arc::mojom::NetworkConfiguration* mojo) { | |
| 173 std::string type = GetStringFromOncDictionary( | |
| 174 dict, onc::network_config::kType, true /* required */); | |
| 175 if (type == onc::network_type::kCellular) { | |
| 176 mojo->type = arc::mojom::NetworkType::CELLULAR; | |
| 177 } else if (type == onc::network_type::kEthernet) { | |
| 178 mojo->type = arc::mojom::NetworkType::ETHERNET; | |
| 179 } else if (type == onc::network_type::kVPN) { | |
| 180 mojo->type = arc::mojom::NetworkType::VPN; | |
| 181 } else if (type == onc::network_type::kWiFi) { | |
| 182 mojo->type = arc::mojom::NetworkType::WIFI; | |
| 183 | |
| 184 const base::DictionaryValue* wifi_dict = nullptr; | |
| 185 dict->GetDictionary(onc::network_config::kWiFi, &wifi_dict); | |
| 186 DCHECK(wifi_dict); | |
| 187 mojo->wifi = TranslateONCWifi(wifi_dict); | |
| 188 } else if (type == onc::network_type::kWimax) { | |
| 189 mojo->type = arc::mojom::NetworkType::WIMAX; | |
| 190 } else { | |
| 191 NOTREACHED(); | |
| 192 } | |
| 193 } | |
| 194 | |
| 195 arc::mojom::NetworkConfigurationPtr TranslateONCConfiguration( | |
| 196 const base::DictionaryValue* dict) { | |
| 197 arc::mojom::NetworkConfigurationPtr mojo = | |
| 198 arc::mojom::NetworkConfiguration::New(); | |
| 199 | |
| 200 mojo->connection_state = TranslateONCConnectionState(dict); | |
| 201 | |
| 202 mojo->guid = GetStringFromOncDictionary(dict, onc::network_config::kGUID, | |
| 203 true /* required */); | |
| 204 | |
| 205 const base::ListValue* ip_config_list = nullptr; | |
| 206 if (dict->GetList(onc::network_config::kIPConfigs, &ip_config_list)) { | |
| 207 DCHECK(ip_config_list); | |
| 208 mojo->ip_configs = TranslateONCIPConfigs(ip_config_list); | |
| 209 } | |
| 210 | |
| 211 mojo->guid = GetStringFromOncDictionary(dict, onc::network_config::kGUID, | |
| 212 true /* required */); | |
| 213 mojo->mac_address = GetStringFromOncDictionary( | |
| 214 dict, onc::network_config::kMacAddress, true /* required */); | |
| 215 TranslateONCNetworkTypeDetails(dict, mojo.get()); | |
| 216 | |
| 217 return mojo; | |
| 218 } | |
| 219 | |
| 220 } // namespace | |
| 221 | |
| 222 namespace arc { | |
| 223 | |
| 56 ArcNetHostImpl::ArcNetHostImpl(ArcBridgeService* bridge_service) | 224 ArcNetHostImpl::ArcNetHostImpl(ArcBridgeService* bridge_service) |
| 57 : ArcService(bridge_service), binding_(this) { | 225 : ArcService(bridge_service), binding_(this) { |
| 58 arc_bridge_service()->AddObserver(this); | 226 arc_bridge_service()->AddObserver(this); |
| 59 GetStateHandler()->AddObserver(this, FROM_HERE); | 227 GetStateHandler()->AddObserver(this, FROM_HERE); |
| 60 } | 228 } |
| 61 | 229 |
| 62 ArcNetHostImpl::~ArcNetHostImpl() { | 230 ArcNetHostImpl::~ArcNetHostImpl() { |
| 63 DCHECK(thread_checker_.CalledOnValidThread()); | 231 DCHECK(thread_checker_.CalledOnValidThread()); |
| 64 arc_bridge_service()->RemoveObserver(this); | 232 arc_bridge_service()->RemoveObserver(this); |
| 65 if (chromeos::NetworkHandler::IsInitialized()) { | 233 if (chromeos::NetworkHandler::IsInitialized()) { |
| (...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 180 VLOG(1) << "CreateNetworkSuccessCallback"; | 348 VLOG(1) << "CreateNetworkSuccessCallback"; |
| 181 mojo_callback.Run(guid); | 349 mojo_callback.Run(guid); |
| 182 } | 350 } |
| 183 | 351 |
| 184 void CreateNetworkFailureCallback( | 352 void CreateNetworkFailureCallback( |
| 185 const arc::mojom::NetHost::CreateNetworkCallback& mojo_callback, | 353 const arc::mojom::NetHost::CreateNetworkCallback& mojo_callback, |
| 186 const std::string& error_name, | 354 const std::string& error_name, |
| 187 std::unique_ptr<base::DictionaryValue> error_data) { | 355 std::unique_ptr<base::DictionaryValue> error_data) { |
| 188 VLOG(1) << "CreateNetworkFailureCallback: " << error_name; | 356 VLOG(1) << "CreateNetworkFailureCallback: " << error_name; |
| 189 mojo_callback.Run(""); | 357 mojo_callback.Run(""); |
| 190 } | 358 } |
|
stevenjb
2016/05/18 23:01:17
Move these two to anon namespace.
Kevin Cernekee
2016/05/18 23:24:53
Done.
| |
| 191 | 359 |
| 192 void ArcNetHostImpl::CreateNetwork(mojom::WifiConfigurationPtr cfg, | 360 void ArcNetHostImpl::CreateNetwork(mojom::WifiConfigurationPtr cfg, |
| 193 const CreateNetworkCallback& callback) { | 361 const CreateNetworkCallback& callback) { |
| 194 if (!IsDeviceOwner()) { | 362 if (!IsDeviceOwner()) { |
| 195 callback.Run(""); | 363 callback.Run(""); |
| 196 return; | 364 return; |
| 197 } | 365 } |
| 198 | 366 |
| 199 std::unique_ptr<base::DictionaryValue> properties(new base::DictionaryValue); | 367 std::unique_ptr<base::DictionaryValue> properties(new base::DictionaryValue); |
| 200 std::unique_ptr<base::DictionaryValue> wifi_dict(new base::DictionaryValue); | 368 std::unique_ptr<base::DictionaryValue> wifi_dict(new base::DictionaryValue); |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 240 const arc::mojom::NetHost::ForgetNetworkCallback& mojo_callback) { | 408 const arc::mojom::NetHost::ForgetNetworkCallback& mojo_callback) { |
| 241 mojo_callback.Run(mojom::NetworkResult::SUCCESS); | 409 mojo_callback.Run(mojom::NetworkResult::SUCCESS); |
| 242 } | 410 } |
| 243 | 411 |
| 244 void ForgetNetworkFailureCallback( | 412 void ForgetNetworkFailureCallback( |
| 245 const arc::mojom::NetHost::ForgetNetworkCallback& mojo_callback, | 413 const arc::mojom::NetHost::ForgetNetworkCallback& mojo_callback, |
| 246 const std::string& error_name, | 414 const std::string& error_name, |
| 247 std::unique_ptr<base::DictionaryValue> error_data) { | 415 std::unique_ptr<base::DictionaryValue> error_data) { |
| 248 VLOG(1) << "ForgetNetworkFailureCallback: " << error_name; | 416 VLOG(1) << "ForgetNetworkFailureCallback: " << error_name; |
| 249 mojo_callback.Run(mojom::NetworkResult::FAILURE); | 417 mojo_callback.Run(mojom::NetworkResult::FAILURE); |
| 250 } | 418 } |
|
stevenjb
2016/05/18 23:01:17
Move these two to anon namespace.
Kevin Cernekee
2016/05/18 23:24:53
Done.
| |
| 251 | 419 |
| 252 void ArcNetHostImpl::ForgetNetwork(const mojo::String& guid, | 420 void ArcNetHostImpl::ForgetNetwork(const mojo::String& guid, |
| 253 const ForgetNetworkCallback& callback) { | 421 const ForgetNetworkCallback& callback) { |
| 254 if (!IsDeviceOwner()) { | 422 if (!IsDeviceOwner()) { |
| 255 callback.Run(mojom::NetworkResult::FAILURE); | 423 callback.Run(mojom::NetworkResult::FAILURE); |
| 256 return; | 424 return; |
| 257 } | 425 } |
| 258 | 426 |
| 259 const chromeos::NetworkState* network = | 427 const chromeos::NetworkState* network = |
| 260 GetStateHandler()->GetNetworkStateFromGuid(guid); | 428 GetStateHandler()->GetNetworkStateFromGuid(guid); |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 273 const arc::mojom::NetHost::StartConnectCallback& mojo_callback) { | 441 const arc::mojom::NetHost::StartConnectCallback& mojo_callback) { |
| 274 mojo_callback.Run(mojom::NetworkResult::SUCCESS); | 442 mojo_callback.Run(mojom::NetworkResult::SUCCESS); |
| 275 } | 443 } |
| 276 | 444 |
| 277 void StartConnectFailureCallback( | 445 void StartConnectFailureCallback( |
| 278 const arc::mojom::NetHost::StartConnectCallback& mojo_callback, | 446 const arc::mojom::NetHost::StartConnectCallback& mojo_callback, |
| 279 const std::string& error_name, | 447 const std::string& error_name, |
| 280 std::unique_ptr<base::DictionaryValue> error_data) { | 448 std::unique_ptr<base::DictionaryValue> error_data) { |
| 281 VLOG(1) << "StartConnectFailureCallback: " << error_name; | 449 VLOG(1) << "StartConnectFailureCallback: " << error_name; |
| 282 mojo_callback.Run(mojom::NetworkResult::FAILURE); | 450 mojo_callback.Run(mojom::NetworkResult::FAILURE); |
| 283 } | 451 } |
|
stevenjb
2016/05/18 23:01:17
Move these two to anon namespace.
Kevin Cernekee
2016/05/18 23:24:53
Done.
| |
| 284 | 452 |
| 285 void ArcNetHostImpl::StartConnect(const mojo::String& guid, | 453 void ArcNetHostImpl::StartConnect(const mojo::String& guid, |
| 286 const StartConnectCallback& callback) { | 454 const StartConnectCallback& callback) { |
| 287 const chromeos::NetworkState* network = | 455 const chromeos::NetworkState* network = |
| 288 GetStateHandler()->GetNetworkStateFromGuid(guid); | 456 GetStateHandler()->GetNetworkStateFromGuid(guid); |
| 289 | 457 |
| 290 if (!network) { | 458 if (!network) { |
| 291 callback.Run(mojom::NetworkResult::FAILURE); | 459 callback.Run(mojom::NetworkResult::FAILURE); |
| 292 return; | 460 return; |
| 293 } | 461 } |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 363 return; | 531 return; |
| 364 } | 532 } |
| 365 if (arc_bridge_service()->net_version() < 1) { | 533 if (arc_bridge_service()->net_version() < 1) { |
| 366 VLOG(1) << "NetInstance does not support ScanCompleted."; | 534 VLOG(1) << "NetInstance does not support ScanCompleted."; |
| 367 return; | 535 return; |
| 368 } | 536 } |
| 369 | 537 |
| 370 arc_bridge_service()->net_instance()->ScanCompleted(); | 538 arc_bridge_service()->net_instance()->ScanCompleted(); |
| 371 } | 539 } |
| 372 | 540 |
| 541 void GetDefaultNetworkSuccessCallback( | |
| 542 const ArcNetHostImpl::GetDefaultNetworkCallback& callback, | |
| 543 const std::string& service_path, | |
| 544 const base::DictionaryValue& dictionary) { | |
| 545 // TODO(cernekee): Figure out how to query Chrome for the default physical | |
| 546 // service if a VPN is connected, rather than just reporting the | |
| 547 // default logical service in both fields. | |
| 548 callback.Run(TranslateONCConfiguration(&dictionary), | |
| 549 TranslateONCConfiguration(&dictionary)); | |
| 550 } | |
| 551 | |
| 552 void GetDefaultNetworkFailureCallback( | |
| 553 const ArcNetHostImpl::GetDefaultNetworkCallback& callback, | |
| 554 const std::string& error_name, | |
| 555 std::unique_ptr<base::DictionaryValue> error_data) { | |
| 556 LOG(ERROR) << "Failed to query default logical network"; | |
| 557 callback.Run(nullptr, nullptr); | |
| 558 } | |
|
stevenjb
2016/05/18 23:01:17
Move these two to anon namespace.
Kevin Cernekee
2016/05/18 23:24:53
Done.
| |
| 559 | |
| 560 void ArcNetHostImpl::GetDefaultNetwork( | |
| 561 const GetDefaultNetworkCallback& callback) { | |
| 562 const chromeos::NetworkState* default_network = | |
| 563 GetStateHandler()->DefaultNetwork(); | |
| 564 if (!default_network) { | |
| 565 VLOG(1) << "GetDefaultNetwork: no default network"; | |
| 566 callback.Run(nullptr, nullptr); | |
| 567 return; | |
| 568 } | |
| 569 VLOG(1) << "GetDefaultNetwork: default network is " | |
| 570 << default_network->path(); | |
| 571 std::string user_id_hash = chromeos::LoginState::Get()->primary_user_hash(); | |
| 572 GetManagedConfigurationHandler()->GetProperties( | |
| 573 user_id_hash, default_network->path(), | |
| 574 base::Bind(&GetDefaultNetworkSuccessCallback, callback), | |
| 575 base::Bind(&GetDefaultNetworkFailureCallback, callback)); | |
| 576 } | |
| 577 | |
| 578 void DefaultNetworkSuccessCallback(ArcNetHostImpl* instance, | |
| 579 const std::string& service_path, | |
| 580 const base::DictionaryValue& dictionary) { | |
| 581 instance->arc_bridge_service()->net_instance()->DefaultNetworkChanged( | |
| 582 TranslateONCConfiguration(&dictionary), | |
| 583 TranslateONCConfiguration(&dictionary)); | |
| 584 } | |
|
stevenjb
2016/05/18 23:01:17
See comment below.
Kevin Cernekee
2016/05/18 23:24:53
Done.
| |
| 585 | |
| 586 void DefaultNetworkFailureCallback( | |
| 587 const std::string& error_name, | |
| 588 std::unique_ptr<base::DictionaryValue> error_data) { | |
| 589 LOG(ERROR) << "Failed to query default logical network"; | |
| 590 } | |
| 591 | |
|
stevenjb
2016/05/18 23:01:17
Move this to anon namespace.
Kevin Cernekee
2016/05/18 23:24:53
Done.
| |
| 592 void ArcNetHostImpl::DefaultNetworkChanged( | |
| 593 const chromeos::NetworkState* network) { | |
| 594 if (arc_bridge_service()->net_version() < 2) { | |
| 595 VLOG(1) << "ArcBridgeService does not support DefaultNetworkChanged."; | |
| 596 return; | |
| 597 } | |
| 598 | |
| 599 if (!network) { | |
| 600 VLOG(1) << "No default network"; | |
| 601 arc_bridge_service()->net_instance()->DefaultNetworkChanged(nullptr, | |
| 602 nullptr); | |
| 603 return; | |
| 604 } | |
| 605 | |
| 606 VLOG(1) << "New default network: " << network->path(); | |
| 607 std::string user_id_hash = chromeos::LoginState::Get()->primary_user_hash(); | |
| 608 GetManagedConfigurationHandler()->GetProperties( | |
| 609 user_id_hash, network->path(), | |
| 610 base::Bind(&DefaultNetworkSuccessCallback, base::Unretained(this)), | |
|
dcheng
2016/05/18 22:31:57
Why is Unretained safe here?
stevenjb
2016/05/18 23:01:17
+1, I missed this (I was mostly focused on the Net
Kevin Cernekee
2016/05/18 23:24:53
Done.
| |
| 611 base::Bind(&DefaultNetworkFailureCallback)); | |
| 612 } | |
| 613 | |
| 373 void ArcNetHostImpl::OnShuttingDown() { | 614 void ArcNetHostImpl::OnShuttingDown() { |
| 374 GetStateHandler()->RemoveObserver(this, FROM_HERE); | 615 GetStateHandler()->RemoveObserver(this, FROM_HERE); |
| 375 } | 616 } |
| 376 | 617 |
| 377 } // namespace arc | 618 } // namespace arc |
| OLD | NEW |