Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(919)

Side by Side Diff: chrome/browser/chromeos/dom_ui/internet_options_handler.cc

Issue 4482003: Landing change for ers@chromium.org: http://codereview.chromium.org/4134012/s... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 10 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2010 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/chromeos/dom_ui/internet_options_handler.h" 5 #include "chrome/browser/chromeos/dom_ui/internet_options_handler.h"
6 6
7 #include <ctype.h> 7 #include <ctype.h>
8 8
9 #include <string> 9 #include <string>
10 #include <vector> 10 #include <vector>
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
49 output.push_back(':'); 49 output.push_back(':');
50 } 50 }
51 output.push_back(toupper(address[i])); 51 output.push_back(toupper(address[i]));
52 } 52 }
53 return output; 53 return output;
54 } 54 }
55 55
56 } // namespace 56 } // namespace
57 57
58 InternetOptionsHandler::InternetOptionsHandler() { 58 InternetOptionsHandler::InternetOptionsHandler() {
59 chromeos::CrosLibrary::Get()->GetNetworkLibrary()->AddObserver(this); 59 chromeos::NetworkLibrary* netlib =
60 chromeos::CrosLibrary::Get()->GetNetworkLibrary();
61 netlib->AddNetworkManagerObserver(this);
62 netlib->AddCellularDataPlanObserver(this);
63 MonitorActiveNetwork(netlib);
60 } 64 }
61 65
62 InternetOptionsHandler::~InternetOptionsHandler() { 66 InternetOptionsHandler::~InternetOptionsHandler() {
63 chromeos::CrosLibrary::Get()->GetNetworkLibrary()->RemoveObserver(this); 67 chromeos::NetworkLibrary *netlib =
68 chromeos::CrosLibrary::Get()->GetNetworkLibrary();
69 netlib->RemoveNetworkManagerObserver(this);
70 netlib->RemoveCellularDataPlanObserver(this);
71 netlib->RemoveObserverForAllNetworks(this);
64 } 72 }
65 73
66 void InternetOptionsHandler::GetLocalizedValues( 74 void InternetOptionsHandler::GetLocalizedValues(
67 DictionaryValue* localized_strings) { 75 DictionaryValue* localized_strings) {
68 DCHECK(localized_strings); 76 DCHECK(localized_strings);
69 // Internet page - ChromeOS 77 // Internet page - ChromeOS
70 localized_strings->SetString("internetPage", 78 localized_strings->SetString("internetPage",
71 l10n_util::GetStringUTF16(IDS_OPTIONS_INTERNET_TAB_LABEL)); 79 l10n_util::GetStringUTF16(IDS_OPTIONS_INTERNET_TAB_LABEL));
72 80
73 localized_strings->SetString("wired_title", 81 localized_strings->SetString("wired_title",
(...skipping 186 matching lines...) Expand 10 before | Expand all | Expand 10 after
260 IDS_OPTIONS_SETTINGS_INTERNET_OPTIONS_CUSTOMER_SUPPORT)); 268 IDS_OPTIONS_SETTINGS_INTERNET_OPTIONS_CUSTOMER_SUPPORT));
261 269
262 localized_strings->SetString("enableWifi", 270 localized_strings->SetString("enableWifi",
263 l10n_util::GetStringFUTF16( 271 l10n_util::GetStringFUTF16(
264 IDS_STATUSBAR_NETWORK_DEVICE_ENABLE, 272 IDS_STATUSBAR_NETWORK_DEVICE_ENABLE,
265 l10n_util::GetStringUTF16(IDS_STATUSBAR_NETWORK_DEVICE_WIFI))); 273 l10n_util::GetStringUTF16(IDS_STATUSBAR_NETWORK_DEVICE_WIFI)));
266 localized_strings->SetString("disableWifi", 274 localized_strings->SetString("disableWifi",
267 l10n_util::GetStringFUTF16( 275 l10n_util::GetStringFUTF16(
268 IDS_STATUSBAR_NETWORK_DEVICE_DISABLE, 276 IDS_STATUSBAR_NETWORK_DEVICE_DISABLE,
269 l10n_util::GetStringUTF16(IDS_STATUSBAR_NETWORK_DEVICE_WIFI))); 277 l10n_util::GetStringUTF16(IDS_STATUSBAR_NETWORK_DEVICE_WIFI)));
270 localized_strings->SetString("enableCellular", 278 localized_strings->SetString("enableCellular",
271 l10n_util::GetStringFUTF16( 279 l10n_util::GetStringFUTF16(
272 IDS_STATUSBAR_NETWORK_DEVICE_ENABLE, 280 IDS_STATUSBAR_NETWORK_DEVICE_ENABLE,
273 l10n_util::GetStringUTF16(IDS_STATUSBAR_NETWORK_DEVICE_CELLULAR))); 281 l10n_util::GetStringUTF16(IDS_STATUSBAR_NETWORK_DEVICE_CELLULAR)));
274 localized_strings->SetString("disableCellular", 282 localized_strings->SetString("disableCellular",
275 l10n_util::GetStringFUTF16( 283 l10n_util::GetStringFUTF16(
276 IDS_STATUSBAR_NETWORK_DEVICE_DISABLE, 284 IDS_STATUSBAR_NETWORK_DEVICE_DISABLE,
277 l10n_util::GetStringUTF16(IDS_STATUSBAR_NETWORK_DEVICE_CELLULAR))); 285 l10n_util::GetStringUTF16(IDS_STATUSBAR_NETWORK_DEVICE_CELLULAR)));
278 localized_strings->SetString("generalNetworkingTitle", 286 localized_strings->SetString("generalNetworkingTitle",
279 l10n_util::GetStringUTF16( 287 l10n_util::GetStringUTF16(
280 IDS_OPTIONS_SETTINGS_INTERNET_CONTROL_TITLE)); 288 IDS_OPTIONS_SETTINGS_INTERNET_CONTROL_TITLE));
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after
350 358
351 void InternetOptionsHandler::BuyDataPlanCallback(const ListValue* args) { 359 void InternetOptionsHandler::BuyDataPlanCallback(const ListValue* args) {
352 if (!dom_ui_) 360 if (!dom_ui_)
353 return; 361 return;
354 Browser* browser = BrowserList::FindBrowserWithFeature( 362 Browser* browser = BrowserList::FindBrowserWithFeature(
355 dom_ui_->GetProfile(), Browser::FEATURE_TABSTRIP); 363 dom_ui_->GetProfile(), Browser::FEATURE_TABSTRIP);
356 if (browser) 364 if (browser)
357 browser->OpenMobilePlanTabAndActivate(); 365 browser->OpenMobilePlanTabAndActivate();
358 } 366 }
359 367
360 void InternetOptionsHandler::NetworkChanged(chromeos::NetworkLibrary* cros) { 368 void InternetOptionsHandler::RefreshNetworkData(
361 if (!dom_ui_) 369 chromeos::NetworkLibrary* cros) {
362 return;
363
364 DictionaryValue dictionary; 370 DictionaryValue dictionary;
365 dictionary.Set("wiredList", GetWiredList()); 371 dictionary.Set("wiredList", GetWiredList());
366 dictionary.Set("wirelessList", GetWirelessList()); 372 dictionary.Set("wirelessList", GetWirelessList());
367 dictionary.Set("rememberedList", GetRememberedList()); 373 dictionary.Set("rememberedList", GetRememberedList());
368 dictionary.SetBoolean("wifiAvailable", cros->wifi_available()); 374 dictionary.SetBoolean("wifiAvailable", cros->wifi_available());
369 dictionary.SetBoolean("wifiEnabled", cros->wifi_enabled()); 375 dictionary.SetBoolean("wifiEnabled", cros->wifi_enabled());
370 dictionary.SetBoolean("cellularAvailable", cros->cellular_available()); 376 dictionary.SetBoolean("cellularAvailable", cros->cellular_available());
371 dictionary.SetBoolean("cellularEnabled", cros->cellular_enabled()); 377 dictionary.SetBoolean("cellularEnabled", cros->cellular_enabled());
372 dom_ui_->CallJavascriptFunction( 378 dom_ui_->CallJavascriptFunction(
373 L"options.InternetOptions.refreshNetworkData", dictionary); 379 L"options.InternetOptions.refreshNetworkData", dictionary);
374 } 380 }
375 381
376 void InternetOptionsHandler::CellularDataPlanChanged( 382 void InternetOptionsHandler::OnNetworkManagerChanged(
383 chromeos::NetworkLibrary* cros) {
384 if (!dom_ui_)
385 return;
386 MonitorActiveNetwork(cros);
387 RefreshNetworkData(cros);
388 }
389
390 void InternetOptionsHandler::OnNetworkChanged(
391 chromeos::NetworkLibrary* cros,
392 const chromeos::Network* network) {
393 if (dom_ui_)
394 RefreshNetworkData(cros);
395 }
396
397 // Add an observer for the active network, if any, so
398 // that we can dynamically display the correct icon for
399 // that network's signal strength.
400 // TODO(ers) Ideally, on this page we'd monitor all networks for
401 // signal strength changes, not just the active network.
402 void InternetOptionsHandler::MonitorActiveNetwork(
403 chromeos::NetworkLibrary* cros) {
404 const chromeos::Network* network = cros->active_network();
405 if (active_network_.empty() || network == NULL ||
406 active_network_ != network->service_path()) {
407 if (!active_network_.empty()) {
408 cros->RemoveNetworkObserver(active_network_, this);
409 }
410 if (network != NULL) {
411 cros->AddNetworkObserver(network->service_path(), this);
412 }
413 }
414 if (network != NULL)
415 active_network_ = network->service_path();
416 else
417 active_network_ = "";
418 }
419
420 void InternetOptionsHandler::OnCellularDataPlanChanged(
377 chromeos::NetworkLibrary* obj) { 421 chromeos::NetworkLibrary* obj) {
378 if (!dom_ui_) 422 if (!dom_ui_)
379 return; 423 return;
380 chromeos::CellularNetwork* cellular = obj->cellular_network(); 424 chromeos::CellularNetwork* cellular = obj->cellular_network();
381 if (!cellular) 425 if (!cellular)
382 return; 426 return;
383 const chromeos::CellularDataPlanVector& plans = cellular->GetDataPlans(); 427 const chromeos::CellularDataPlanVector& plans = cellular->GetDataPlans();
384 DictionaryValue connection_plans; 428 DictionaryValue connection_plans;
385 ListValue* plan_list = new ListValue(); 429 ListValue* plan_list = new ListValue();
386 for (chromeos::CellularDataPlanVector::const_iterator iter = plans.begin(); 430 for (chromeos::CellularDataPlanVector::const_iterator iter = plans.begin();
(...skipping 186 matching lines...) Expand 10 before | Expand all | Expand 10 after
573 dictionary.SetBoolean("connecting", net->connecting()); 617 dictionary.SetBoolean("connecting", net->connecting());
574 dictionary.SetBoolean("connected", net->connected()); 618 dictionary.SetBoolean("connected", net->connected());
575 dictionary.SetString("connectionState", net->GetStateString()); 619 dictionary.SetString("connectionState", net->GetStateString());
576 if (type == chromeos::TYPE_WIFI) { 620 if (type == chromeos::TYPE_WIFI) {
577 chromeos::WifiNetwork* wireless = 621 chromeos::WifiNetwork* wireless =
578 cros->FindWifiNetworkByPath(net->service_path()); 622 cros->FindWifiNetworkByPath(net->service_path());
579 if (!wireless) { 623 if (!wireless) {
580 LOG(WARNING) << "Cannot find network " << net->service_path(); 624 LOG(WARNING) << "Cannot find network " << net->service_path();
581 } else { 625 } else {
582 dictionary.SetString("ssid", wireless->name()); 626 dictionary.SetString("ssid", wireless->name());
583 dictionary.SetBoolean("autoConnect",wireless->auto_connect()); 627 dictionary.SetBoolean("autoConnect", wireless->auto_connect());
584 if (wireless->encrypted()) { 628 if (wireless->encrypted()) {
585 dictionary.SetBoolean("encrypted", true); 629 dictionary.SetBoolean("encrypted", true);
586 if (wireless->encryption() == chromeos::SECURITY_8021X) { 630 if (wireless->encryption() == chromeos::SECURITY_8021X) {
587 bool certificate_in_pkcs11 = 631 bool certificate_in_pkcs11 =
588 is_certificate_in_pkcs11(wireless->cert_path()); 632 is_certificate_in_pkcs11(wireless->cert_path());
589 if (certificate_in_pkcs11) { 633 if (certificate_in_pkcs11) {
590 dictionary.SetBoolean("certInPkcs", true); 634 dictionary.SetBoolean("certInPkcs", true);
591 } else { 635 } else {
592 dictionary.SetBoolean("certInPkcs", false); 636 dictionary.SetBoolean("certInPkcs", false);
593 } 637 }
594 dictionary.SetString("certPath",wireless->cert_path()); 638 dictionary.SetString("certPath", wireless->cert_path());
595 dictionary.SetString("ident",wireless->identity()); 639 dictionary.SetString("ident", wireless->identity());
596 dictionary.SetBoolean("certNeeded", true); 640 dictionary.SetBoolean("certNeeded", true);
597 dictionary.SetString("certPass",wireless->passphrase()); 641 dictionary.SetString("certPass", wireless->passphrase());
598 } else { 642 } else {
599 dictionary.SetBoolean("certNeeded", false); 643 dictionary.SetBoolean("certNeeded", false);
600 } 644 }
601 } else { 645 } else {
602 dictionary.SetBoolean("encrypted", false); 646 dictionary.SetBoolean("encrypted", false);
603 } 647 }
604 } 648 }
605 } else if (type == chromeos::TYPE_CELLULAR) { 649 } else if (type == chromeos::TYPE_CELLULAR) {
606 chromeos::CellularNetwork* cellular = 650 chromeos::CellularNetwork* cellular =
607 cros->FindCellularNetworkByPath(net->service_path()); 651 cros->FindCellularNetworkByPath(net->service_path());
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after
648 FormatHardwareAddress(hardware_address)); 692 FormatHardwareAddress(hardware_address));
649 } 693 }
650 694
651 dom_ui_->CallJavascriptFunction( 695 dom_ui_->CallJavascriptFunction(
652 L"options.InternetOptions.showDetailedInfo", dictionary); 696 L"options.InternetOptions.showDetailedInfo", dictionary);
653 } 697 }
654 698
655 void InternetOptionsHandler::PopupWirelessPassword( 699 void InternetOptionsHandler::PopupWirelessPassword(
656 const chromeos::WifiNetwork* network) { 700 const chromeos::WifiNetwork* network) {
657 DictionaryValue dictionary; 701 DictionaryValue dictionary;
658 dictionary.SetString("servicePath",network->service_path()); 702 dictionary.SetString("servicePath", network->service_path());
659 if (network->encryption() == chromeos::SECURITY_8021X) { 703 if (network->encryption() == chromeos::SECURITY_8021X) {
660 dictionary.SetBoolean("certNeeded", true); 704 dictionary.SetBoolean("certNeeded", true);
661 dictionary.SetString("ident", network->identity()); 705 dictionary.SetString("ident", network->identity());
662 dictionary.SetString("cert", network->cert_path()); 706 dictionary.SetString("cert", network->cert_path());
663 } else { 707 } else {
664 dictionary.SetBoolean("certNeeded", false); 708 dictionary.SetBoolean("certNeeded", false);
665 } 709 }
666 dom_ui_->CallJavascriptFunction( 710 dom_ui_->CallJavascriptFunction(
667 L"options.InternetOptions.showPasswordEntry", dictionary); 711 L"options.InternetOptions.showPasswordEntry", dictionary);
668 } 712 }
669 713
670 void InternetOptionsHandler::LoginCallback(const ListValue* args) { 714 void InternetOptionsHandler::LoginCallback(const ListValue* args) {
671
672 std::string service_path; 715 std::string service_path;
673 std::string password; 716 std::string password;
674 717
675 if (args->GetSize() != 2 || 718 if (args->GetSize() != 2 ||
676 !args->GetString(0, &service_path) || 719 !args->GetString(0, &service_path) ||
677 !args->GetString(1, &password)) { 720 !args->GetString(1, &password)) {
678 NOTREACHED(); 721 NOTREACHED();
679 return; 722 return;
680 } 723 }
681 724
682 chromeos::NetworkLibrary* cros = 725 chromeos::NetworkLibrary* cros =
683 chromeos::CrosLibrary::Get()->GetNetworkLibrary(); 726 chromeos::CrosLibrary::Get()->GetNetworkLibrary();
684 chromeos::WifiNetwork* network = cros->FindWifiNetworkByPath(service_path); 727 chromeos::WifiNetwork* network = cros->FindWifiNetworkByPath(service_path);
685 if (network) { 728 if (network) {
686 cros->ConnectToWifiNetwork( 729 cros->ConnectToWifiNetwork(
687 network, password, std::string(), std::string()); 730 network, password, std::string(), std::string());
688 } else { 731 } else {
689 // Network disappeared while the user is connecting to it. 732 // Network disappeared while the user is connecting to it.
690 // TODO(chocobo): Display error message. 733 // TODO(chocobo): Display error message.
691 LOG(WARNING) << "Cannot find network to connect " << service_path; 734 LOG(WARNING) << "Cannot find network to connect " << service_path;
692 } 735 }
693 } 736 }
694 737
695 void InternetOptionsHandler::LoginCertCallback(const ListValue* args) { 738 void InternetOptionsHandler::LoginCertCallback(const ListValue* args) {
696
697 std::string service_path; 739 std::string service_path;
698 std::string identity; 740 std::string identity;
699 std::string certpath; 741 std::string certpath;
700 if (args->GetSize() < 3 || 742 if (args->GetSize() < 3 ||
701 !args->GetString(0, &service_path) || 743 !args->GetString(0, &service_path) ||
702 !args->GetString(1, &certpath) || 744 !args->GetString(1, &certpath) ||
703 !args->GetString(2, &identity)) { 745 !args->GetString(2, &identity)) {
704 return; 746 return;
705 } 747 }
706 chromeos::NetworkLibrary* cros = 748 chromeos::NetworkLibrary* cros =
(...skipping 220 matching lines...) Expand 10 before | Expand all | Expand 10 after
927 false, 969 false,
928 chromeos::ACTIVATION_STATE_UNKNOWN)); 970 chromeos::ACTIVATION_STATE_UNKNOWN));
929 } 971 }
930 972
931 const chromeos::CellularNetworkVector cellular_networks = 973 const chromeos::CellularNetworkVector cellular_networks =
932 cros->cellular_networks(); 974 cros->cellular_networks();
933 for (chromeos::CellularNetworkVector::const_iterator it = 975 for (chromeos::CellularNetworkVector::const_iterator it =
934 cellular_networks.begin(); it != cellular_networks.end(); ++it) { 976 cellular_networks.begin(); it != cellular_networks.end(); ++it) {
935 SkBitmap icon = chromeos::NetworkMenu::IconForNetworkStrength( 977 SkBitmap icon = chromeos::NetworkMenu::IconForNetworkStrength(
936 (*it)->strength(), true); 978 (*it)->strength(), true);
937 SkBitmap badge = *rb.GetBitmapNamed(IDR_STATUSBAR_NETWORK_3G); 979 SkBitmap badge = chromeos::NetworkMenu::BadgeForNetworkTechnology(*it);
938 icon = chromeos::NetworkMenu::IconForDisplay(icon, badge); 980 icon = chromeos::NetworkMenu::IconForDisplay(icon, badge);
939 list->Append(GetNetwork( 981 list->Append(GetNetwork(
940 (*it)->service_path(), 982 (*it)->service_path(),
941 icon, 983 icon,
942 (*it)->name(), 984 (*it)->name(),
943 (*it)->connecting(), 985 (*it)->connecting(),
944 (*it)->connected(), 986 (*it)->connected(),
945 chromeos::TYPE_CELLULAR, 987 chromeos::TYPE_CELLULAR,
946 false, 988 false,
947 (*it)->activation_state())); 989 (*it)->activation_state()));
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
983 icon, 1025 icon,
984 (*it)->name(), 1026 (*it)->name(),
985 (*it)->connecting(), 1027 (*it)->connecting(),
986 (*it)->connected(), 1028 (*it)->connected(),
987 chromeos::TYPE_WIFI, 1029 chromeos::TYPE_WIFI,
988 true, 1030 true,
989 chromeos::ACTIVATION_STATE_UNKNOWN)); 1031 chromeos::ACTIVATION_STATE_UNKNOWN));
990 } 1032 }
991 return list; 1033 return list;
992 } 1034 }
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/dom_ui/internet_options_handler.h ('k') | chrome/browser/chromeos/dom_ui/mobile_setup_ui.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698