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 352 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 363 return; | 363 return; |
| 364 } | 364 } |
| 365 if (arc_bridge_service()->net_version() < 1) { | 365 if (arc_bridge_service()->net_version() < 1) { |
| 366 VLOG(1) << "NetInstance does not support ScanCompleted."; | 366 VLOG(1) << "NetInstance does not support ScanCompleted."; |
| 367 return; | 367 return; |
| 368 } | 368 } |
| 369 | 369 |
| 370 arc_bridge_service()->net_instance()->ScanCompleted(); | 370 arc_bridge_service()->net_instance()->ScanCompleted(); |
| 371 } | 371 } |
| 372 | 372 |
| 373 mojom::WiFiPtr TranslateONCWifi(const base::DictionaryValue* dict) { | |
| 374 mojom::WiFiPtr mojo = mojom::WiFi::New(); | |
| 375 std::string tmp; | |
| 376 | |
| 377 if (!dict->GetInteger(onc::wifi::kFrequency, &mojo->frequency)) | |
| 378 NOTREACHED(); | |
|
stevenjb
2016/05/16 19:29:35
Frequency is not a required ONC property, we shoul
Kevin Cernekee
2016/05/17 01:56:27
Done.
| |
| 379 | |
| 380 if (!dict->GetString(onc::wifi::kBSSID, &tmp)) | |
| 381 NOTREACHED(); | |
|
stevenjb
2016/05/16 19:29:35
Ditto.
Kevin Cernekee
2016/05/17 01:56:27
Done.
| |
| 382 DCHECK(!tmp.empty()); | |
| 383 mojo->bssid = tmp; | |
| 384 | |
| 385 tmp.clear(); | |
| 386 if (!dict->GetString(onc::wifi::kHexSSID, &tmp)) | |
| 387 NOTREACHED(); | |
| 388 DCHECK(!tmp.empty()); | |
| 389 mojo->hex_ssid = tmp; | |
|
stevenjb
2016/05/16 19:29:35
This pattern is used a lot. I think the code in th
Kevin Cernekee
2016/05/17 01:56:27
Done.
| |
| 390 | |
| 391 if (!dict->GetBoolean(onc::wifi::kHiddenSSID, &mojo->hidden_ssid)) | |
| 392 NOTREACHED(); | |
|
stevenjb
2016/05/16 19:29:35
Optional, defaults to false.
Kevin Cernekee
2016/05/17 01:56:27
Done.
| |
| 393 | |
| 394 tmp.clear(); | |
| 395 if (!dict->GetString(onc::wifi::kSecurity, &tmp)) | |
| 396 NOTREACHED(); | |
| 397 DCHECK(!tmp.empty()); | |
| 398 if (tmp == onc::wifi::kWEP_PSK) | |
| 399 mojo->security = mojom::SecurityType::WEP_PSK; | |
| 400 else if (tmp == onc::wifi::kWEP_8021X) | |
| 401 mojo->security = mojom::SecurityType::WEP_8021X; | |
| 402 else if (tmp == onc::wifi::kWPA_PSK) | |
| 403 mojo->security = mojom::SecurityType::WPA_PSK; | |
| 404 else if (tmp == onc::wifi::kWPA_EAP) | |
| 405 mojo->security = mojom::SecurityType::WPA_EAP; | |
| 406 else | |
| 407 NOTREACHED(); | |
|
stevenjb
2016/05/16 19:29:35
nit: Move this conversion to a helper function.
Kevin Cernekee
2016/05/17 01:56:27
Done.
| |
| 408 | |
| 409 if (!dict->GetInteger(onc::wifi::kSignalStrength, &mojo->signal_strength)) | |
| 410 NOTREACHED(); | |
|
stevenjb
2016/05/16 19:29:35
Optional, defaults to 0
Kevin Cernekee
2016/05/17 01:56:27
Done.
| |
| 411 | |
| 412 return mojo; | |
| 413 } | |
| 414 | |
| 415 mojo::Array<mojo::String> TranslateStringArray(const base::ListValue* list) { | |
| 416 mojo::Array<mojo::String> mojos = mojo::Array<mojo::String>::New(0); | |
| 417 | |
| 418 for (size_t i = 0; i < list->GetSize(); i++) { | |
| 419 std::string tmp; | |
| 420 if (!list->GetString(i, &tmp)) | |
| 421 NOTREACHED(); | |
| 422 DCHECK(!tmp.empty()); | |
| 423 | |
| 424 mojo::String element; | |
| 425 element = tmp; | |
| 426 mojos.push_back(element); | |
| 427 } | |
| 428 | |
| 429 return mojos; | |
| 430 } | |
|
stevenjb
2016/05/16 19:29:35
This seems like a generally useful utility functio
Kevin Cernekee
2016/05/17 01:56:27
Acknowledged.
| |
| 431 | |
| 432 mojo::Array<mojom::IPConfigurationPtr> TranslateONCIPConfigs( | |
| 433 const base::ListValue* list) { | |
| 434 mojo::Array<mojom::IPConfigurationPtr> mojos = | |
| 435 mojo::Array<mojom::IPConfigurationPtr>::New(0); | |
| 436 | |
| 437 for (size_t i = 0; i < list->GetSize(); i++) { | |
| 438 const base::DictionaryValue* ip_dict = nullptr; | |
| 439 mojom::IPConfigurationPtr mojo = mojom::IPConfiguration::New(); | |
| 440 | |
| 441 list->GetDictionary(i, &ip_dict); | |
| 442 DCHECK(ip_dict); | |
| 443 | |
| 444 std::string tmp; | |
| 445 if (!ip_dict->GetString(onc::ipconfig::kGateway, &tmp)) | |
| 446 NOTREACHED(); | |
| 447 DCHECK(!tmp.empty()); | |
| 448 mojo->gateway = tmp; | |
| 449 | |
| 450 tmp.clear(); | |
| 451 if (!ip_dict->GetString(onc::ipconfig::kIPAddress, &tmp)) | |
| 452 NOTREACHED(); | |
| 453 DCHECK(!tmp.empty()); | |
| 454 mojo->ip_address = tmp; | |
| 455 | |
| 456 const base::ListValue* dns_list; | |
| 457 if (ip_dict->GetList(onc::ipconfig::kNameServers, &dns_list)) | |
| 458 mojo->name_servers = TranslateStringArray(dns_list); | |
| 459 else | |
| 460 NOTREACHED(); | |
|
stevenjb
2016/05/16 19:29:35
This should be written:
if (!...GetList...)
NOTR
Kevin Cernekee
2016/05/17 01:56:27
Done.
| |
| 461 | |
| 462 if (!ip_dict->GetInteger(onc::ipconfig::kRoutingPrefix, | |
| 463 &mojo->routing_prefix)) | |
| 464 NOTREACHED(); | |
|
stevenjb
2016/05/16 19:29:35
{}
Kevin Cernekee
2016/05/17 01:56:27
Done.
| |
| 465 | |
| 466 tmp.clear(); | |
| 467 if (!ip_dict->GetString(onc::ipconfig::kType, &tmp)) | |
| 468 NOTREACHED(); | |
| 469 DCHECK(!tmp.empty()); | |
| 470 if (tmp == onc::ipconfig::kIPv4) | |
| 471 mojo->type = mojom::IPAddressType::IPV4; | |
| 472 else if (tmp == onc::ipconfig::kIPv6) | |
| 473 mojo->type = mojom::IPAddressType::IPV6; | |
| 474 else | |
| 475 NOTREACHED(); | |
|
stevenjb
2016/05/16 19:29:35
More simply:
mojo->type = tmp == onc::ipconfig::kI
Kevin Cernekee
2016/05/17 01:56:26
Done.
| |
| 476 | |
| 477 tmp.clear(); | |
| 478 if (!ip_dict->GetString(onc::ipconfig::kWebProxyAutoDiscoveryUrl, &tmp)) | |
| 479 NOTREACHED(); | |
| 480 DCHECK(!tmp.empty()); | |
| 481 mojo->web_proxy_auto_discovery_url = tmp; | |
| 482 | |
| 483 mojos.push_back(std::move(mojo)); | |
| 484 } | |
| 485 return mojos; | |
| 486 } | |
| 487 | |
| 488 mojom::NetworkConfigurationPtr TranslateONCConfiguration( | |
| 489 const base::DictionaryValue* dict) { | |
| 490 mojom::NetworkConfigurationPtr mojo = mojom::NetworkConfiguration::New(); | |
| 491 std::string tmp; | |
| 492 | |
| 493 if (!dict->GetString(onc::network_config::kConnectionState, &tmp)) | |
| 494 NOTREACHED(); | |
| 495 DCHECK(!tmp.empty()); | |
| 496 if (tmp == onc::connection_state::kConnected) | |
| 497 mojo->connection_state = mojom::ConnectionStateType::CONNECTED; | |
| 498 else if (tmp == onc::connection_state::kConnecting) | |
| 499 mojo->connection_state = mojom::ConnectionStateType::CONNECTING; | |
| 500 else if (tmp == onc::connection_state::kNotConnected) | |
| 501 mojo->connection_state = mojom::ConnectionStateType::NOT_CONNECTED; | |
| 502 else | |
| 503 NOTREACHED(); | |
|
stevenjb
2016/05/16 19:29:35
nit: helper function
Kevin Cernekee
2016/05/17 01:56:27
Done.
| |
| 504 | |
| 505 tmp.clear(); | |
| 506 if (!dict->GetString(onc::network_config::kGUID, &tmp)) | |
| 507 NOTREACHED(); | |
| 508 DCHECK(!tmp.empty()); | |
| 509 mojo->guid = tmp; | |
| 510 | |
| 511 const base::ListValue* ip_config_list = nullptr; | |
| 512 if (dict->GetList(onc::network_config::kIPConfigs, &ip_config_list)) { | |
| 513 DCHECK(ip_config_list); | |
| 514 mojo->ip_configs = TranslateONCIPConfigs(ip_config_list); | |
| 515 } | |
| 516 | |
| 517 tmp.clear(); | |
| 518 if (dict->GetString(onc::network_config::kMacAddress, &tmp)) { | |
| 519 DCHECK(!tmp.empty()); | |
| 520 mojo->mac_address = tmp; | |
| 521 } | |
| 522 | |
| 523 tmp.clear(); | |
| 524 if (!dict->GetString(onc::network_config::kType, &tmp)) | |
| 525 NOTREACHED(); | |
| 526 DCHECK(!tmp.empty()); | |
| 527 if (tmp == onc::network_type::kCellular) { | |
| 528 mojo->type = mojom::NetworkType::CELLULAR; | |
| 529 } else if (tmp == onc::network_type::kEthernet) { | |
| 530 mojo->type = mojom::NetworkType::ETHERNET; | |
| 531 } else if (tmp == onc::network_type::kVPN) { | |
| 532 mojo->type = mojom::NetworkType::VPN; | |
| 533 } else if (tmp == onc::network_type::kWiFi) { | |
| 534 mojo->type = mojom::NetworkType::WIFI; | |
| 535 | |
| 536 const base::DictionaryValue* wifi_dict = nullptr; | |
| 537 dict->GetDictionary(onc::network_config::kWiFi, &wifi_dict); | |
| 538 DCHECK(wifi_dict); | |
| 539 mojo->wifi = TranslateONCWifi(wifi_dict); | |
| 540 } else if (tmp == onc::network_type::kWimax) { | |
| 541 mojo->type = mojom::NetworkType::WIMAX; | |
| 542 } | |
| 543 | |
| 544 return mojo; | |
| 545 } | |
| 546 | |
| 547 void GetDefaultNetworkSuccessCallback( | |
| 548 const ArcNetHostImpl::GetDefaultNetworkCallback& callback, | |
| 549 const std::string& service_path, | |
| 550 const base::DictionaryValue& dictionary) { | |
| 551 // TODO(cernekee): Figure out how to query Chrome for the default physical | |
| 552 // service if a VPN is connected, rather than just reporting the | |
| 553 // default logical service in both fields. | |
|
stevenjb
2016/05/16 19:29:35
string type;
if (dictionary->GetString(kType, &typ
Kevin Cernekee
2016/05/17 01:56:27
Ack, will handle this in a separate CL.
| |
| 554 callback.Run(TranslateONCConfiguration(&dictionary), | |
| 555 TranslateONCConfiguration(&dictionary)); | |
| 556 } | |
| 557 | |
| 558 void GetDefaultNetworkFailureCallback( | |
| 559 const ArcNetHostImpl::GetDefaultNetworkCallback& callback, | |
| 560 const std::string& error_name, | |
| 561 std::unique_ptr<base::DictionaryValue> error_data) { | |
| 562 LOG(ERROR) << "Failed to query default logical network"; | |
| 563 callback.Run(nullptr, nullptr); | |
| 564 } | |
| 565 | |
| 566 void ArcNetHostImpl::GetDefaultNetwork( | |
| 567 const GetDefaultNetworkCallback& callback) { | |
| 568 std::string user_id_hash = chromeos::LoginState::Get()->primary_user_hash(); | |
| 569 GetManagedConfigurationHandler()->GetProperties( | |
| 570 user_id_hash, default_network_, | |
| 571 base::Bind(&GetDefaultNetworkSuccessCallback, callback), | |
| 572 base::Bind(&GetDefaultNetworkFailureCallback, callback)); | |
| 573 } | |
| 574 | |
| 575 void DefaultNetworkSuccessCallback(ArcNetHostImpl* instance, | |
| 576 const std::string& service_path, | |
| 577 const base::DictionaryValue& dictionary) { | |
| 578 instance->arc_bridge_service()->net_instance()->DefaultNetworkChanged( | |
| 579 TranslateONCConfiguration(&dictionary), | |
| 580 TranslateONCConfiguration(&dictionary)); | |
| 581 } | |
| 582 | |
| 583 void DefaultNetworkFailureCallback( | |
| 584 const std::string& error_name, | |
| 585 std::unique_ptr<base::DictionaryValue> error_data) { | |
| 586 LOG(ERROR) << "Failed to query default logical network"; | |
| 587 } | |
| 588 | |
| 589 void ArcNetHostImpl::DefaultNetworkChanged( | |
| 590 const chromeos::NetworkState* network) { | |
| 591 if (!network) { | |
| 592 default_network_.clear(); | |
| 593 VLOG(1) << "No default network"; | |
| 594 } else { | |
| 595 default_network_ = network->path(); | |
| 596 VLOG(1) << "New default network: " << default_network_; | |
| 597 } | |
| 598 | |
| 599 if (arc_bridge_service()->net_version() < 2) { | |
| 600 VLOG(1) << "ArcBridgeService does not support DefaultNetworkChanged."; | |
| 601 return; | |
| 602 } | |
| 603 | |
| 604 if (default_network_.empty()) { | |
|
stevenjb
2016/05/16 19:29:35
Not possible. (You can add a DCHECK to document th
Kevin Cernekee
2016/05/17 01:56:26
We hit this case when network is NULL (i.e. all in
stevenjb
2016/05/17 18:02:41
I see. I would restructure this function:
if (!ne
| |
| 605 arc_bridge_service()->net_instance()->DefaultNetworkChanged(nullptr, | |
| 606 nullptr); | |
| 607 } else { | |
| 608 std::string user_id_hash = chromeos::LoginState::Get()->primary_user_hash(); | |
| 609 GetManagedConfigurationHandler()->GetProperties( | |
| 610 user_id_hash, default_network_, | |
| 611 base::Bind(&DefaultNetworkSuccessCallback, base::Unretained(this)), | |
|
stevenjb
2016/05/16 19:29:35
You should just bind default_network here instead
Kevin Cernekee
2016/05/17 01:56:26
We set it as a member because we usually get a Def
stevenjb
2016/05/17 18:02:41
As noted: I think it is better to let NetworkState
| |
| 612 base::Bind(&DefaultNetworkFailureCallback)); | |
| 613 } | |
| 614 } | |
| 615 | |
| 373 void ArcNetHostImpl::OnShuttingDown() { | 616 void ArcNetHostImpl::OnShuttingDown() { |
| 374 GetStateHandler()->RemoveObserver(this, FROM_HERE); | 617 GetStateHandler()->RemoveObserver(this, FROM_HERE); |
| 375 } | 618 } |
| 376 | 619 |
| 377 } // namespace arc | 620 } // namespace arc |
| OLD | NEW |