summaryrefslogtreecommitdiffstats
path: root/chromeos
diff options
context:
space:
mode:
Diffstat (limited to 'chromeos')
-rw-r--r--chromeos/dbus/fake_shill_service_client.cc34
-rw-r--r--chromeos/network/managed_network_configuration_handler_impl.cc11
-rw-r--r--chromeos/network/network_state.cc8
-rw-r--r--chromeos/network/network_state.h3
-rw-r--r--chromeos/network/network_state_handler.cc10
-rw-r--r--chromeos/network/network_state_handler.h4
-rw-r--r--chromeos/network/network_util.cc2
-rw-r--r--chromeos/network/onc/onc_translation_tables.cc15
-rw-r--r--chromeos/network/onc/onc_translator.h10
-rw-r--r--chromeos/network/onc/onc_translator_shill_to_onc.cc42
-rw-r--r--chromeos/network/onc/onc_translator_unittest.cc3
-rw-r--r--chromeos/network/policy_applicator.cc6
12 files changed, 49 insertions, 99 deletions
diff --git a/chromeos/dbus/fake_shill_service_client.cc b/chromeos/dbus/fake_shill_service_client.cc
index fdae9db..d4e789c3 100644
--- a/chromeos/dbus/fake_shill_service_client.cc
+++ b/chromeos/dbus/fake_shill_service_client.cc
@@ -178,8 +178,8 @@ void FakeShillServiceClient::Connect(const dbus::ObjectPath& service_path,
const ErrorCallback& error_callback) {
VLOG(1) << "FakeShillServiceClient::Connect: " << service_path.value();
base::DictionaryValue* service_properties = NULL;
- if (!stub_services_.GetDictionary(service_path.value(),
- &service_properties)) {
+ if (!stub_services_.GetDictionary(
+ service_path.value(), &service_properties)) {
LOG(ERROR) << "Service not found: " << service_path.value();
error_callback.Run("Error.InvalidService", "Invalid Service");
return;
@@ -190,22 +190,21 @@ void FakeShillServiceClient::Connect(const dbus::ObjectPath& service_path,
// sending an update.
SetOtherServicesOffline(service_path.value());
- // Clear Error.
- service_properties->SetStringWithoutPathExpansion(shill::kErrorProperty, "");
-
// Set Associating.
base::StringValue associating_value(shill::kStateAssociation);
- SetServiceProperty(service_path.value(), shill::kStateProperty,
+ SetServiceProperty(service_path.value(),
+ shill::kStateProperty,
associating_value);
// Stay Associating until the state is changed again after a delay.
base::MessageLoop::current()->PostDelayedTask(
FROM_HERE,
base::Bind(&FakeShillServiceClient::ContinueConnect,
- weak_ptr_factory_.GetWeakPtr(), service_path.value()),
+ weak_ptr_factory_.GetWeakPtr(),
+ service_path.value()),
base::TimeDelta::FromSeconds(GetInteractiveDelay()));
- base::MessageLoop::current()->PostTask(FROM_HERE, callback);
+ callback.Run();
}
void FakeShillServiceClient::Disconnect(const dbus::ObjectPath& service_path,
@@ -607,7 +606,8 @@ void FakeShillServiceClient::SetCellularActivated(
error_callback);
}
-void FakeShillServiceClient::ContinueConnect(const std::string& service_path) {
+void FakeShillServiceClient::ContinueConnect(
+ const std::string& service_path) {
VLOG(1) << "FakeShillServiceClient::ContinueConnect: " << service_path;
base::DictionaryValue* service_properties = NULL;
if (!stub_services_.GetDictionary(service_path, &service_properties)) {
@@ -625,24 +625,26 @@ void FakeShillServiceClient::ContinueConnect(const std::string& service_path) {
// No custom connect behavior set, continue with the default connect behavior.
std::string passphrase;
- service_properties->GetStringWithoutPathExpansion(shill::kPassphraseProperty,
- &passphrase);
+ service_properties->GetStringWithoutPathExpansion(
+ shill::kPassphraseProperty, &passphrase);
if (passphrase == "failure") {
// Simulate a password failure.
- SetServiceProperty(service_path, shill::kErrorProperty,
- base::StringValue(shill::kErrorBadPassphrase));
- SetServiceProperty(service_path, shill::kStateProperty,
+ SetServiceProperty(service_path,
+ shill::kStateProperty,
base::StringValue(shill::kStateFailure));
base::MessageLoop::current()->PostTask(
FROM_HERE,
base::Bind(
base::IgnoreResult(&FakeShillServiceClient::SetServiceProperty),
- weak_ptr_factory_.GetWeakPtr(), service_path, shill::kErrorProperty,
+ weak_ptr_factory_.GetWeakPtr(),
+ service_path,
+ shill::kErrorProperty,
base::StringValue(shill::kErrorBadPassphrase)));
} else {
// Set Online.
VLOG(1) << "Setting state to Online " << service_path;
- SetServiceProperty(service_path, shill::kStateProperty,
+ SetServiceProperty(service_path,
+ shill::kStateProperty,
base::StringValue(shill::kStateOnline));
}
}
diff --git a/chromeos/network/managed_network_configuration_handler_impl.cc b/chromeos/network/managed_network_configuration_handler_impl.cc
index f20cdcc3..a92be66 100644
--- a/chromeos/network/managed_network_configuration_handler_impl.cc
+++ b/chromeos/network/managed_network_configuration_handler_impl.cc
@@ -164,12 +164,9 @@ void ManagedNetworkConfigurationHandlerImpl::SendManagedProperties(
::onc::ONCSource onc_source;
FindPolicyByGUID(userhash, guid, &onc_source);
- const NetworkState* network_state =
- network_state_handler_->GetNetworkState(service_path);
scoped_ptr<base::DictionaryValue> active_settings(
- onc::TranslateShillServiceToONCPart(*shill_properties, onc_source,
- &onc::kNetworkWithStateSignature,
- network_state));
+ onc::TranslateShillServiceToONCPart(
+ *shill_properties, onc_source, &onc::kNetworkWithStateSignature));
const base::DictionaryValue* network_policy = NULL;
const base::DictionaryValue* global_policy = NULL;
@@ -216,12 +213,10 @@ void ManagedNetworkConfigurationHandlerImpl::SendProperties(
const network_handler::ErrorCallback& error_callback,
const std::string& service_path,
scoped_ptr<base::DictionaryValue> shill_properties) {
- const NetworkState* network_state =
- network_state_handler_->GetNetworkState(service_path);
scoped_ptr<base::DictionaryValue> onc_network(
onc::TranslateShillServiceToONCPart(
*shill_properties, ::onc::ONC_SOURCE_UNKNOWN,
- &onc::kNetworkWithStateSignature, network_state));
+ &onc::kNetworkWithStateSignature));
callback.Run(service_path, *onc_network);
}
diff --git a/chromeos/network/network_state.cc b/chromeos/network/network_state.cc
index 93c12e4..f4ad959 100644
--- a/chromeos/network/network_state.cc
+++ b/chromeos/network/network_state.cc
@@ -231,6 +231,8 @@ void NetworkState::GetStateProperties(base::DictionaryValue* dictionary) const {
profile_path());
if (visible()) {
+ if (!error().empty())
+ dictionary->SetStringWithoutPathExpansion(shill::kErrorProperty, error());
dictionary->SetStringWithoutPathExpansion(shill::kStateProperty,
connection_state());
}
@@ -396,12 +398,6 @@ bool NetworkState::UpdateName(const base::DictionaryValue& properties) {
return false;
}
-std::string NetworkState::GetErrorState() const {
- if (ErrorIsValid(error()))
- return error();
- return last_error();
-}
-
// static
bool NetworkState::StateIsConnected(const std::string& connection_state) {
return (connection_state == shill::kStateReady ||
diff --git a/chromeos/network/network_state.h b/chromeos/network/network_state.h
index 518e568..e4d9cce 100644
--- a/chromeos/network/network_state.h
+++ b/chromeos/network/network_state.h
@@ -126,9 +126,6 @@ class CHROMEOS_EXPORT NetworkState : public ManagedState {
// Set the GUID. Called exclusively by NetworkStateHandler.
void SetGuid(const std::string& guid);
- // Returns |error_| if valid, otherwise returns |last_error_|.
- std::string GetErrorState() const;
-
// Helpers (used e.g. when a state, error, or shill dictionary is cached)
static bool StateIsConnected(const std::string& connection_state);
static bool StateIsConnecting(const std::string& connection_state);
diff --git a/chromeos/network/network_state_handler.cc b/chromeos/network/network_state_handler.cc
index a8a9ebf..236789c 100644
--- a/chromeos/network/network_state_handler.cc
+++ b/chromeos/network/network_state_handler.cc
@@ -417,16 +417,6 @@ const NetworkState* NetworkStateHandler::GetEAPForEthernet(
return list.front();
}
-void NetworkStateHandler::SetLastErrorForTest(const std::string& service_path,
- const std::string& error) {
- NetworkState* network_state = GetModifiableNetworkState(service_path);
- if (!network_state) {
- LOG(ERROR) << "No matching NetworkState for: " << service_path;
- return;
- }
- network_state->last_error_ = error;
-}
-
//------------------------------------------------------------------------------
// ShillPropertyHandler::Delegate overrides
diff --git a/chromeos/network/network_state_handler.h b/chromeos/network/network_state_handler.h
index f032f77..135d225 100644
--- a/chromeos/network/network_state_handler.h
+++ b/chromeos/network/network_state_handler.h
@@ -224,10 +224,6 @@ class CHROMEOS_EXPORT NetworkStateHandler
return default_network_path_;
}
- // Sets the |last_error_| property of the matching NetworkState for tests.
- void SetLastErrorForTest(const std::string& service_path,
- const std::string& error);
-
// Constructs and initializes an instance for testing.
static NetworkStateHandler* InitializeForTest();
diff --git a/chromeos/network/network_util.cc b/chromeos/network/network_util.cc
index 5fa7de5..b5d50b3 100644
--- a/chromeos/network/network_util.cc
+++ b/chromeos/network/network_util.cc
@@ -179,7 +179,7 @@ scoped_ptr<base::DictionaryValue> TranslateNetworkStateToONC(
scoped_ptr<base::DictionaryValue> onc_dictionary =
TranslateShillServiceToONCPart(*shill_dictionary, onc_source,
- &onc::kNetworkWithStateSignature, network);
+ &onc::kNetworkWithStateSignature);
return onc_dictionary.Pass();
}
diff --git a/chromeos/network/onc/onc_translation_tables.cc b/chromeos/network/onc/onc_translation_tables.cc
index ad7eef8..285a7e1 100644
--- a/chromeos/network/onc/onc_translation_tables.cc
+++ b/chromeos/network/onc/onc_translation_tables.cc
@@ -187,23 +187,24 @@ const FieldTranslationEntry cellular_fields[] = {
const FieldTranslationEntry network_fields[] = {
{::onc::network_config::kGUID, shill::kGuidProperty},
{::onc::network_config::kConnectable, shill::kConnectableProperty},
+ {::onc::network_config::kErrorState, shill::kErrorProperty},
{::onc::network_config::kPriority, shill::kPriorityProperty},
// Shill doesn't allow setting the name for non-VPN networks.
// Name is conditionally translated, see onc_translator_*.
- // {::onc::network_config::kName, shill::kNameProperty },
+ // { ::onc::network_config::kName, shill::kNameProperty },
// Type is converted during translation, see onc_translator_*.
- // {::onc::network_config::kType, shill::kTypeProperty },
+ // { ::onc::network_config::kType, shill::kTypeProperty },
// These fields are converted during translation, see
// onc_translator_shill_to_onc.cc. They are only converted when going from
// Shill->ONC, and ignored otherwise.
- // {::onc::network_config::kConnectionState, shill::kStateProperty },
- // {::onc::network_config::kErrorState, shill::kErrorProperty},
- // {::onc::network_config::kRestrictedConnectivity, shill::kStateProperty },
- // {::onc::network_config::kSource, shill::kProfileProperty },
- // {::onc::network_config::kMacAddress, shill::kAddressProperty },
+ // { ::onc::network_config::kConnectionState, shill::kStateProperty },
+ // { ::onc::network_config::kRestrictedConnectivity,
+ // shill::kStateProperty },
+ // { ::onc::network_config::kSource, shill::kProfileProperty },
+ // { ::onc::network_config::kMacAddress, shill::kAddressProperty },
{NULL}};
const FieldTranslationEntry ipconfig_fields[] = {
diff --git a/chromeos/network/onc/onc_translator.h b/chromeos/network/onc/onc_translator.h
index db1cb71..dc5afa3 100644
--- a/chromeos/network/onc/onc_translator.h
+++ b/chromeos/network/onc/onc_translator.h
@@ -14,9 +14,6 @@ class DictionaryValue;
}
namespace chromeos {
-
-class NetworkState;
-
namespace onc {
struct OncValueSignature;
@@ -42,15 +39,12 @@ scoped_ptr<base::DictionaryValue> TranslateONCObjectToShill(
// only a subset of it and includes only the values that are actually required
// by the UI. If |onc_source| != ONC_SOURCE_UNKNOWN then the 'Source' property
// of the ONC dictionary will be set accordingly. Note: ONC_SOURCE_USER_IMPORT
-// is treated the same as ONC_SOURCE_NONE. If |network_state| is provided it
-// will be used to set the ErrorState property. Otherwise ErrorState will not
-// be set.
+// is treated the same as ONC_SOURCE_NONE.
CHROMEOS_EXPORT
scoped_ptr<base::DictionaryValue> TranslateShillServiceToONCPart(
const base::DictionaryValue& shill_dictionary,
::onc::ONCSource onc_source,
- const OncValueSignature* onc_signature,
- const NetworkState* network_state);
+ const OncValueSignature* onc_signature);
} // namespace onc
} // namespace chromeos
diff --git a/chromeos/network/onc/onc_translator_shill_to_onc.cc b/chromeos/network/onc/onc_translator_shill_to_onc.cc
index aca9133..d918156 100644
--- a/chromeos/network/onc/onc_translator_shill_to_onc.cc
+++ b/chromeos/network/onc/onc_translator_shill_to_onc.cc
@@ -52,25 +52,21 @@ class ShillToONCTranslator {
public:
ShillToONCTranslator(const base::DictionaryValue& shill_dictionary,
::onc::ONCSource onc_source,
- const OncValueSignature& onc_signature,
- const NetworkState* network_state)
+ const OncValueSignature& onc_signature)
: shill_dictionary_(&shill_dictionary),
onc_source_(onc_source),
- onc_signature_(&onc_signature),
- network_state_(network_state) {
+ onc_signature_(&onc_signature) {
field_translation_table_ = GetFieldTranslationTable(onc_signature);
}
ShillToONCTranslator(const base::DictionaryValue& shill_dictionary,
::onc::ONCSource onc_source,
const OncValueSignature& onc_signature,
- const FieldTranslationEntry* field_translation_table,
- const NetworkState* network_state)
+ const FieldTranslationEntry* field_translation_table)
: shill_dictionary_(&shill_dictionary),
onc_source_(onc_source),
onc_signature_(&onc_signature),
- field_translation_table_(field_translation_table),
- network_state_(network_state) {}
+ field_translation_table_(field_translation_table) {}
// Translates the associated Shill dictionary and creates an ONC object of the
// given signature.
@@ -146,7 +142,6 @@ class ShillToONCTranslator {
const OncValueSignature* onc_signature_;
const FieldTranslationEntry* field_translation_table_;
scoped_ptr<base::DictionaryValue> onc_object_;
- const NetworkState* network_state_;
DISALLOW_COPY_AND_ASSIGN(ShillToONCTranslator);
};
@@ -387,9 +382,9 @@ void ShillToONCTranslator::TranslateCellularWithState() {
if (device_dictionary) {
// Merge the Device dictionary with this one (Cellular) using the
// CellularDevice signature.
- ShillToONCTranslator nested_translator(
- *device_dictionary, onc_source_, kCellularWithStateSignature,
- kCellularDeviceTable, network_state_);
+ ShillToONCTranslator nested_translator(*device_dictionary, onc_source_,
+ kCellularWithStateSignature,
+ kCellularDeviceTable);
scoped_ptr<base::DictionaryValue> nested_object =
nested_translator.CreateTranslatedONCObject();
onc_object_->MergeDictionary(nested_object.get());
@@ -479,17 +474,6 @@ void ShillToONCTranslator::TranslateNetworkWithState() {
}
}
- // 'ErrorState' reflects the most recent error maintained in NetworkState
- // (which may not match Shill's Error or PreviousError properties). Non
- // visible networks (with null network_state_) do not set ErrorState.
- if (network_state_) {
- std::string error_state = network_state_->GetErrorState();
- if (!error_state.empty()) {
- onc_object_->SetStringWithoutPathExpansion(
- ::onc::network_config::kErrorState, error_state);
- }
- }
-
std::string profile_path;
if (onc_source_ != ::onc::ONC_SOURCE_UNKNOWN &&
shill_dictionary_->GetStringWithoutPathExpansion(shill::kProfileProperty,
@@ -617,8 +601,7 @@ void ShillToONCTranslator::TranslateAndAddNestedObject(
return;
}
ShillToONCTranslator nested_translator(dictionary, onc_source_,
- *field_signature->value_signature,
- network_state_);
+ *field_signature->value_signature);
scoped_ptr<base::DictionaryValue> nested_object =
nested_translator.CreateTranslatedONCObject();
if (nested_object->empty())
@@ -659,8 +642,7 @@ void ShillToONCTranslator::TranslateAndAddListOfObjects(
continue;
ShillToONCTranslator nested_translator(
*shill_value, onc_source_,
- *field_signature->value_signature->onc_array_entry_signature,
- network_state_);
+ *field_signature->value_signature->onc_array_entry_signature);
scoped_ptr<base::DictionaryValue> nested_object =
nested_translator.CreateTranslatedONCObject();
// If the nested object couldn't be parsed, simply omit it.
@@ -746,12 +728,10 @@ std::string ShillToONCTranslator::GetName() {
scoped_ptr<base::DictionaryValue> TranslateShillServiceToONCPart(
const base::DictionaryValue& shill_dictionary,
::onc::ONCSource onc_source,
- const OncValueSignature* onc_signature,
- const NetworkState* network_state) {
+ const OncValueSignature* onc_signature) {
CHECK(onc_signature != NULL);
- ShillToONCTranslator translator(shill_dictionary, onc_source, *onc_signature,
- network_state);
+ ShillToONCTranslator translator(shill_dictionary, onc_source, *onc_signature);
return translator.CreateTranslatedONCObject();
}
diff --git a/chromeos/network/onc/onc_translator_unittest.cc b/chromeos/network/onc/onc_translator_unittest.cc
index 45701c6..f637761 100644
--- a/chromeos/network/onc/onc_translator_unittest.cc
+++ b/chromeos/network/onc/onc_translator_unittest.cc
@@ -83,8 +83,7 @@ TEST_P(ONCTranslatorShillToOncTest, Translate) {
test_utils::ReadTestDictionary(result_onc_filename));
scoped_ptr<base::DictionaryValue> translation(TranslateShillServiceToONCPart(
- *shill_network, ::onc::ONC_SOURCE_NONE, &kNetworkWithStateSignature,
- nullptr /* network_state */));
+ *shill_network, ::onc::ONC_SOURCE_NONE, &kNetworkWithStateSignature));
EXPECT_TRUE(test_utils::Equals(expected_onc_network.get(),
translation.get()));
diff --git a/chromeos/network/policy_applicator.cc b/chromeos/network/policy_applicator.cc
index a5dd9ff..53ff817 100644
--- a/chromeos/network/policy_applicator.cc
+++ b/chromeos/network/policy_applicator.cc
@@ -131,9 +131,9 @@ void PolicyApplicator::GetEntryCallback(
<< profile_.ToDebugString();
scoped_ptr<base::DictionaryValue> onc_part(
- onc::TranslateShillServiceToONCPart(
- entry_properties, ::onc::ONC_SOURCE_UNKNOWN,
- &onc::kNetworkWithStateSignature, nullptr /* network_state */));
+ onc::TranslateShillServiceToONCPart(entry_properties,
+ ::onc::ONC_SOURCE_UNKNOWN,
+ &onc::kNetworkWithStateSignature));
std::string old_guid;
if (!onc_part->GetStringWithoutPathExpansion(::onc::network_config::kGUID,