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 "ash/system/chromeos/network/network_state_notifier.h" | 5 #include "ash/system/chromeos/network/network_state_notifier.h" |
6 | 6 |
7 #include "ash/shell.h" | 7 #include "ash/shell.h" |
8 #include "ash/system/chromeos/network/network_connect.h" | 8 #include "ash/system/chromeos/network/network_connect.h" |
9 #include "ash/system/system_notifier.h" | 9 #include "ash/system/system_notifier.h" |
10 #include "ash/system/tray/system_tray_delegate.h" | 10 #include "ash/system/tray/system_tray_delegate.h" |
(...skipping 178 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
189 l10n_util::GetStringFUTF16(IDS_NETWORK_CELLULAR_ACTIVATED, | 189 l10n_util::GetStringFUTF16(IDS_NETWORK_CELLULAR_ACTIVATED, |
190 UTF8ToUTF16((cellular->name()))), | 190 UTF8ToUTF16((cellular->name()))), |
191 icon, | 191 icon, |
192 system_notifier::NOTIFIER_NETWORK, | 192 system_notifier::NOTIFIER_NETWORK, |
193 base::Bind(&ash::network_connect::ShowNetworkSettings, | 193 base::Bind(&ash::network_connect::ShowNetworkSettings, |
194 cellular->path()))); | 194 cellular->path()))); |
195 } | 195 } |
196 | 196 |
197 void NetworkStateNotifier::ShowNetworkConnectError( | 197 void NetworkStateNotifier::ShowNetworkConnectError( |
198 const std::string& error_name, | 198 const std::string& error_name, |
| 199 const std::string& shill_error, |
199 const std::string& service_path) { | 200 const std::string& service_path) { |
200 if (service_path.empty()) { | 201 if (service_path.empty()) { |
201 base::DictionaryValue shill_properties; | 202 base::DictionaryValue shill_properties; |
202 ShowConnectErrorNotification(error_name, service_path, shill_properties); | 203 ShowConnectErrorNotification(error_name, shill_error, service_path, |
| 204 shill_properties); |
203 return; | 205 return; |
204 } | 206 } |
205 // Get the up-to-date properties for the network and display the error. | 207 // Get the up-to-date properties for the network and display the error. |
206 NetworkHandler::Get()->network_configuration_handler()->GetProperties( | 208 NetworkHandler::Get()->network_configuration_handler()->GetProperties( |
207 service_path, | 209 service_path, |
208 base::Bind(&NetworkStateNotifier::ConnectErrorPropertiesSucceeded, | 210 base::Bind(&NetworkStateNotifier::ConnectErrorPropertiesSucceeded, |
209 weak_ptr_factory_.GetWeakPtr(), error_name), | 211 weak_ptr_factory_.GetWeakPtr(), error_name, shill_error), |
210 base::Bind(&NetworkStateNotifier::ConnectErrorPropertiesFailed, | 212 base::Bind(&NetworkStateNotifier::ConnectErrorPropertiesFailed, |
211 weak_ptr_factory_.GetWeakPtr(), error_name, service_path)); | 213 weak_ptr_factory_.GetWeakPtr(), error_name, shill_error, |
| 214 service_path)); |
212 } | 215 } |
213 | 216 |
214 void NetworkStateNotifier::ConnectErrorPropertiesSucceeded( | 217 void NetworkStateNotifier::ConnectErrorPropertiesSucceeded( |
215 const std::string& error_name, | 218 const std::string& error_name, |
| 219 const std::string& shill_error, |
216 const std::string& service_path, | 220 const std::string& service_path, |
217 const base::DictionaryValue& shill_properties) { | 221 const base::DictionaryValue& shill_properties) { |
218 ShowConnectErrorNotification(error_name, service_path, shill_properties); | 222 ShowConnectErrorNotification(error_name, shill_error, service_path, |
| 223 shill_properties); |
219 } | 224 } |
220 | 225 |
221 void NetworkStateNotifier::ConnectErrorPropertiesFailed( | 226 void NetworkStateNotifier::ConnectErrorPropertiesFailed( |
222 const std::string& error_name, | 227 const std::string& error_name, |
| 228 const std::string& shill_error, |
223 const std::string& service_path, | 229 const std::string& service_path, |
224 const std::string& shill_error_name, | 230 const std::string& shill_connect_error, |
225 scoped_ptr<base::DictionaryValue> shill_error_data) { | 231 scoped_ptr<base::DictionaryValue> shill_error_data) { |
226 base::DictionaryValue shill_properties; | 232 base::DictionaryValue shill_properties; |
227 ShowConnectErrorNotification(error_name, service_path, shill_properties); | 233 ShowConnectErrorNotification(error_name, shill_error, service_path, |
| 234 shill_properties); |
228 } | 235 } |
229 | 236 |
230 void NetworkStateNotifier::ShowConnectErrorNotification( | 237 void NetworkStateNotifier::ShowConnectErrorNotification( |
231 const std::string& error_name, | 238 const std::string& error_name, |
| 239 const std::string& shill_error, |
232 const std::string& service_path, | 240 const std::string& service_path, |
233 const base::DictionaryValue& shill_properties) { | 241 const base::DictionaryValue& shill_properties) { |
234 string16 error = GetConnectErrorString(error_name); | 242 string16 error = GetConnectErrorString(error_name); |
235 if (error.empty()) { | 243 if (error.empty()) { |
236 std::string network_error; | 244 // Service.Error gets cleared shortly after State transitions to Failure, |
237 shill_properties.GetStringWithoutPathExpansion( | 245 // so rely on |shill_error| unless empty. |
238 flimflam::kErrorProperty, &network_error); | 246 std::string network_error = shill_error; |
| 247 if (network_error.empty()) { |
| 248 shill_properties.GetStringWithoutPathExpansion( |
| 249 flimflam::kErrorProperty, &network_error); |
| 250 } |
239 error = network_connect::ErrorString(network_error); | 251 error = network_connect::ErrorString(network_error); |
240 if (error.empty()) | 252 if (error.empty()) |
241 error = l10n_util::GetStringUTF16(IDS_CHROMEOS_NETWORK_ERROR_UNKNOWN); | 253 error = l10n_util::GetStringUTF16(IDS_CHROMEOS_NETWORK_ERROR_UNKNOWN); |
242 } | 254 } |
243 NET_LOG_ERROR("Connect error notification: " + UTF16ToUTF8(error), | 255 NET_LOG_ERROR("Connect error notification: " + UTF16ToUTF8(error), |
244 service_path); | 256 service_path); |
245 | 257 |
246 std::string network_name = | 258 std::string network_name = |
247 chromeos::shill_property_util::GetNameFromProperties(service_path, | 259 chromeos::shill_property_util::GetNameFromProperties(service_path, |
248 shill_properties); | 260 shill_properties); |
(...skipping 23 matching lines...) Expand all Loading... |
272 | 284 |
273 ShowErrorNotification( | 285 ShowErrorNotification( |
274 network_connect::kNetworkConnectNotificationId, | 286 network_connect::kNetworkConnectNotificationId, |
275 network_type, | 287 network_type, |
276 l10n_util::GetStringUTF16(IDS_NETWORK_CONNECTION_ERROR_TITLE), | 288 l10n_util::GetStringUTF16(IDS_NETWORK_CONNECTION_ERROR_TITLE), |
277 error_msg, | 289 error_msg, |
278 base::Bind(&network_connect::ShowNetworkSettings, service_path)); | 290 base::Bind(&network_connect::ShowNetworkSettings, service_path)); |
279 } | 291 } |
280 | 292 |
281 } // namespace ash | 293 } // namespace ash |
OLD | NEW |