OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "chromeos/network/network_state_handler.h" | 5 #include "chromeos/network/network_state_handler.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/format_macros.h" | 8 #include "base/format_macros.h" |
9 #include "base/guid.h" | 9 #include "base/guid.h" |
| 10 #include "base/json/json_string_value_serializer.h" |
| 11 #include "base/json/json_writer.h" |
10 #include "base/location.h" | 12 #include "base/location.h" |
11 #include "base/logging.h" | 13 #include "base/logging.h" |
12 #include "base/metrics/histogram.h" | 14 #include "base/metrics/histogram.h" |
13 #include "base/stl_util.h" | 15 #include "base/stl_util.h" |
14 #include "base/strings/string_util.h" | 16 #include "base/strings/string_util.h" |
15 #include "base/strings/stringprintf.h" | 17 #include "base/strings/stringprintf.h" |
16 #include "base/values.h" | 18 #include "base/values.h" |
17 #include "chromeos/network/device_state.h" | 19 #include "chromeos/network/device_state.h" |
18 #include "chromeos/network/managed_state.h" | 20 #include "chromeos/network/managed_state.h" |
19 #include "chromeos/network/network_event_log.h" | 21 #include "chromeos/network/network_event_log.h" |
(...skipping 24 matching lines...) Expand all Loading... |
44 return ""; | 46 return ""; |
45 } | 47 } |
46 | 48 |
47 std::string GetLogName(const ManagedState* state) { | 49 std::string GetLogName(const ManagedState* state) { |
48 if (!state) | 50 if (!state) |
49 return "None"; | 51 return "None"; |
50 return base::StringPrintf("%s (%s)", state->name().c_str(), | 52 return base::StringPrintf("%s (%s)", state->name().c_str(), |
51 state->path().c_str()); | 53 state->path().c_str()); |
52 } | 54 } |
53 | 55 |
| 56 std::string ValueAsString(const base::Value& value) { |
| 57 std::string vstr; |
| 58 base::JSONWriter::WriteWithOptions( |
| 59 &value, base::JSONWriter::OPTIONS_OMIT_BINARY_VALUES, &vstr); |
| 60 return vstr.empty() ? "''" : vstr; |
| 61 } |
| 62 |
54 } // namespace | 63 } // namespace |
55 | 64 |
56 const char NetworkStateHandler::kDefaultCheckPortalList[] = | 65 const char NetworkStateHandler::kDefaultCheckPortalList[] = |
57 "ethernet,wifi,cellular"; | 66 "ethernet,wifi,cellular"; |
58 | 67 |
59 NetworkStateHandler::NetworkStateHandler() | 68 NetworkStateHandler::NetworkStateHandler() |
60 : network_list_sorted_(false) { | 69 : network_list_sorted_(false) { |
61 } | 70 } |
62 | 71 |
63 NetworkStateHandler::~NetworkStateHandler() { | 72 NetworkStateHandler::~NetworkStateHandler() { |
(...skipping 11 matching lines...) Expand all Loading... |
75 NetworkStateHandler* NetworkStateHandler::InitializeForTest() { | 84 NetworkStateHandler* NetworkStateHandler::InitializeForTest() { |
76 NetworkStateHandler* handler = new NetworkStateHandler(); | 85 NetworkStateHandler* handler = new NetworkStateHandler(); |
77 handler->InitShillPropertyHandler(); | 86 handler->InitShillPropertyHandler(); |
78 return handler; | 87 return handler; |
79 } | 88 } |
80 | 89 |
81 void NetworkStateHandler::AddObserver( | 90 void NetworkStateHandler::AddObserver( |
82 NetworkStateHandlerObserver* observer, | 91 NetworkStateHandlerObserver* observer, |
83 const tracked_objects::Location& from_here) { | 92 const tracked_objects::Location& from_here) { |
84 observers_.AddObserver(observer); | 93 observers_.AddObserver(observer); |
85 network_event_log::internal::AddEntry( | 94 device_event_log::AddEntry(from_here.file_name(), from_here.line_number(), |
86 from_here.file_name(), from_here.line_number(), | 95 device_event_log::LOG_TYPE_NETWORK, |
87 network_event_log::LOG_LEVEL_DEBUG, | 96 device_event_log::LOG_LEVEL_DEBUG, |
88 "NetworkStateHandler::AddObserver", ""); | 97 "NetworkStateHandler::AddObserver"); |
89 } | 98 } |
90 | 99 |
91 void NetworkStateHandler::RemoveObserver( | 100 void NetworkStateHandler::RemoveObserver( |
92 NetworkStateHandlerObserver* observer, | 101 NetworkStateHandlerObserver* observer, |
93 const tracked_objects::Location& from_here) { | 102 const tracked_objects::Location& from_here) { |
94 observers_.RemoveObserver(observer); | 103 observers_.RemoveObserver(observer); |
95 network_event_log::internal::AddEntry( | 104 device_event_log::AddEntry(from_here.file_name(), from_here.line_number(), |
96 from_here.file_name(), from_here.line_number(), | 105 device_event_log::LOG_TYPE_NETWORK, |
97 network_event_log::LOG_LEVEL_DEBUG, | 106 device_event_log::LOG_LEVEL_DEBUG, |
98 "NetworkStateHandler::RemoveObserver", ""); | 107 "NetworkStateHandler::RemoveObserver"); |
99 } | 108 } |
100 | 109 |
101 NetworkStateHandler::TechnologyState NetworkStateHandler::GetTechnologyState( | 110 NetworkStateHandler::TechnologyState NetworkStateHandler::GetTechnologyState( |
102 const NetworkTypePattern& type) const { | 111 const NetworkTypePattern& type) const { |
103 std::string technology = GetTechnologyForType(type); | 112 std::string technology = GetTechnologyForType(type); |
104 TechnologyState state; | 113 TechnologyState state; |
105 if (shill_property_handler_->IsTechnologyEnabled(technology)) | 114 if (shill_property_handler_->IsTechnologyEnabled(technology)) |
106 state = TECHNOLOGY_ENABLED; | 115 state = TECHNOLOGY_ENABLED; |
107 else if (shill_property_handler_->IsTechnologyEnabling(technology)) | 116 else if (shill_property_handler_->IsTechnologyEnabling(technology)) |
108 state = TECHNOLOGY_ENABLING; | 117 state = TECHNOLOGY_ENABLING; |
(...skipping 453 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
562 key != shill::kWifiFrequencyListProperty && | 571 key != shill::kWifiFrequencyListProperty && |
563 (key != shill::kDeviceProperty || value_str != "/")) { | 572 (key != shill::kDeviceProperty || value_str != "/")) { |
564 std::string log_event = "NetworkPropertyUpdated"; | 573 std::string log_event = "NetworkPropertyUpdated"; |
565 // Trigger a default network update for interesting changes only. | 574 // Trigger a default network update for interesting changes only. |
566 if (network->path() == default_network_path_) { | 575 if (network->path() == default_network_path_) { |
567 NotifyDefaultNetworkChanged(network); | 576 NotifyDefaultNetworkChanged(network); |
568 log_event = "Default" + log_event; | 577 log_event = "Default" + log_event; |
569 } | 578 } |
570 // Log event. | 579 // Log event. |
571 std::string detail = network->name() + "." + key; | 580 std::string detail = network->name() + "." + key; |
572 detail += " = " + network_event_log::ValueAsString(value); | 581 detail += " = " + ValueAsString(value); |
573 network_event_log::LogLevel log_level; | 582 device_event_log::LogLevel log_level; |
574 if (key == shill::kErrorProperty || key == shill::kErrorDetailsProperty) { | 583 if (key == shill::kErrorProperty || key == shill::kErrorDetailsProperty) { |
575 log_level = network_event_log::LOG_LEVEL_ERROR; | 584 log_level = device_event_log::LOG_LEVEL_ERROR; |
576 } else { | 585 } else { |
577 log_level = network_event_log::LOG_LEVEL_EVENT; | 586 log_level = device_event_log::LOG_LEVEL_EVENT; |
578 } | 587 } |
579 NET_LOG_LEVEL(log_level, log_event, detail); | 588 NET_LOG_LEVEL(log_level, log_event, detail); |
580 } | 589 } |
581 } | 590 } |
582 | 591 |
583 // All property updates signal 'NetworkPropertiesUpdated'. | 592 // All property updates signal 'NetworkPropertiesUpdated'. |
584 NotifyNetworkPropertiesUpdated(network); | 593 NotifyNetworkPropertiesUpdated(network); |
585 | 594 |
586 // If added to a Profile, request a full update so that a NetworkState | 595 // If added to a Profile, request a full update so that a NetworkState |
587 // gets created. | 596 // gets created. |
588 if (prev_profile_path.empty() && !network->profile_path().empty()) | 597 if (prev_profile_path.empty() && !network->profile_path().empty()) |
589 RequestUpdateForNetwork(service_path); | 598 RequestUpdateForNetwork(service_path); |
590 } | 599 } |
591 | 600 |
592 void NetworkStateHandler::UpdateDeviceProperty(const std::string& device_path, | 601 void NetworkStateHandler::UpdateDeviceProperty(const std::string& device_path, |
593 const std::string& key, | 602 const std::string& key, |
594 const base::Value& value) { | 603 const base::Value& value) { |
595 DeviceState* device = GetModifiableDeviceState(device_path); | 604 DeviceState* device = GetModifiableDeviceState(device_path); |
596 if (!device) | 605 if (!device) |
597 return; | 606 return; |
598 if (!device->PropertyChanged(key, value)) | 607 if (!device->PropertyChanged(key, value)) |
599 return; | 608 return; |
600 | 609 |
601 std::string detail = device->name() + "." + key; | 610 std::string detail = device->name() + "." + key; |
602 detail += " = " + network_event_log::ValueAsString(value); | 611 detail += " = " + ValueAsString(value); |
603 NET_LOG_EVENT("DevicePropertyUpdated", detail); | 612 NET_LOG_EVENT("DevicePropertyUpdated", detail); |
604 | 613 |
605 NotifyDeviceListChanged(); | 614 NotifyDeviceListChanged(); |
606 NotifyDevicePropertiesUpdated(device); | 615 NotifyDevicePropertiesUpdated(device); |
607 | 616 |
608 if (key == shill::kScanningProperty && device->scanning() == false) { | 617 if (key == shill::kScanningProperty && device->scanning() == false) { |
609 NotifyScanCompleted(device); | 618 NotifyScanCompleted(device); |
610 } | 619 } |
611 if (key == shill::kEapAuthenticationCompletedProperty) { | 620 if (key == shill::kEapAuthenticationCompletedProperty) { |
612 // Notify a change for each Ethernet service using this device. | 621 // Notify a change for each Ethernet service using this device. |
(...skipping 330 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
943 if (type.MatchesType(shill::kTypeBluetooth)) | 952 if (type.MatchesType(shill::kTypeBluetooth)) |
944 technologies.push_back(new std::string(shill::kTypeBluetooth)); | 953 technologies.push_back(new std::string(shill::kTypeBluetooth)); |
945 if (type.MatchesType(shill::kTypeVPN)) | 954 if (type.MatchesType(shill::kTypeVPN)) |
946 technologies.push_back(new std::string(shill::kTypeVPN)); | 955 technologies.push_back(new std::string(shill::kTypeVPN)); |
947 | 956 |
948 CHECK_GT(technologies.size(), 0ul); | 957 CHECK_GT(technologies.size(), 0ul); |
949 return technologies.Pass(); | 958 return technologies.Pass(); |
950 } | 959 } |
951 | 960 |
952 } // namespace chromeos | 961 } // namespace chromeos |
OLD | NEW |