diff options
author | noamsml@chromium.org <noamsml@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-06-04 08:41:22 +0000 |
---|---|---|
committer | noamsml@chromium.org <noamsml@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-06-04 08:41:22 +0000 |
commit | ca11059ee2dd9abe0c64b47cda1f58d6c662e855 (patch) | |
tree | 16daa9bbc8d59d1f9f9c9affb9ea28f487918431 /components/wifi/network_properties.cc | |
parent | a4af7d5f79be09c03b36d86964500195aec4fc70 (diff) | |
download | chromium_src-ca11059ee2dd9abe0c64b47cda1f58d6c662e855.zip chromium_src-ca11059ee2dd9abe0c64b47cda1f58d6c662e855.tar.gz chromium_src-ca11059ee2dd9abe0c64b47cda1f58d6c662e855.tar.bz2 |
This is a library for Windows and MacOSX (tested MacOSX currently) that supports the features needed to do WiFi bootstrapping.
BUG=370071
Review URL: https://codereview.chromium.org/226883002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@274731 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'components/wifi/network_properties.cc')
-rw-r--r-- | components/wifi/network_properties.cc | 121 |
1 files changed, 121 insertions, 0 deletions
diff --git a/components/wifi/network_properties.cc b/components/wifi/network_properties.cc new file mode 100644 index 0000000..3ab12da --- /dev/null +++ b/components/wifi/network_properties.cc @@ -0,0 +1,121 @@ +// Copyright 2014 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "components/wifi/network_properties.h" + +#include "base/json/json_reader.h" +#include "base/message_loop/message_loop.h" +#include "base/strings/stringprintf.h" +#include "components/onc/onc_constants.h" + +namespace wifi { + +NetworkProperties::NetworkProperties() + : connection_state(onc::connection_state::kNotConnected), + security(onc::wifi::kNone), + signal_strength(0), + auto_connect(false), + frequency(kFrequencyUnknown) { +} + +NetworkProperties::~NetworkProperties() { +} + +scoped_ptr<base::DictionaryValue> NetworkProperties::ToValue( + bool network_list) const { + scoped_ptr<base::DictionaryValue> value(new base::DictionaryValue()); + + value->SetString(onc::network_config::kGUID, guid); + value->SetString(onc::network_config::kName, name); + value->SetString(onc::network_config::kConnectionState, connection_state); + DCHECK(type == onc::network_type::kWiFi); + value->SetString(onc::network_config::kType, type); + + // For now, assume all WiFi services are connectable. + value->SetBoolean(onc::network_config::kConnectable, true); + + scoped_ptr<base::DictionaryValue> wifi(new base::DictionaryValue()); + wifi->SetString(onc::wifi::kSecurity, security); + wifi->SetInteger(onc::wifi::kSignalStrength, signal_strength); + + // Network list expects subset of data. + if (!network_list) { + if (frequency != kFrequencyUnknown) + wifi->SetInteger(onc::wifi::kFrequency, frequency); + scoped_ptr<base::ListValue> frequency_list(new base::ListValue()); + for (FrequencySet::const_iterator it = this->frequency_set.begin(); + it != this->frequency_set.end(); + ++it) { + frequency_list->AppendInteger(*it); + } + if (!frequency_list->empty()) + wifi->Set(onc::wifi::kFrequencyList, frequency_list.release()); + if (!bssid.empty()) + wifi->SetString(onc::wifi::kBSSID, bssid); + wifi->SetString(onc::wifi::kSSID, ssid); + } + value->Set(onc::network_type::kWiFi, wifi.release()); + + if (!network_list && !json_extra.empty()) { + base::Value* value_extra = base::JSONReader::Read(json_extra); + CHECK(value_extra); + base::DictionaryValue* value_dictionary; + if (value_extra->GetAsDictionary(&value_dictionary)) + value->MergeDictionary(value_dictionary); + } + + return value.Pass(); +} + +bool NetworkProperties::UpdateFromValue(const base::DictionaryValue& value) { + const base::DictionaryValue* wifi = NULL; + std::string network_type; + // Get network type and make sure that it is WiFi (if specified). + if (value.GetString(onc::network_config::kType, &network_type)) { + if (network_type != onc::network_type::kWiFi) + return false; + type = network_type; + } + if (value.GetDictionary(onc::network_type::kWiFi, &wifi)) { + value.GetString(onc::network_config::kName, &name); + value.GetString(onc::network_config::kGUID, &guid); + value.GetString(onc::network_config::kConnectionState, &connection_state); + wifi->GetString(onc::wifi::kSecurity, &security); + wifi->GetString(onc::wifi::kSSID, &ssid); + wifi->GetString(onc::wifi::kPassphrase, &password); + wifi->GetBoolean(onc::wifi::kAutoConnect, &auto_connect); + return true; + } + return false; +} + +std::string NetworkProperties::MacAddressAsString(const uint8 mac_as_int[6]) { + // mac_as_int is big-endian. Write in byte chunks. + // Format is XX:XX:XX:XX:XX:XX. + static const char* const kMacFormatString = "%02x:%02x:%02x:%02x:%02x:%02x"; + return base::StringPrintf(kMacFormatString, + mac_as_int[0], + mac_as_int[1], + mac_as_int[2], + mac_as_int[3], + mac_as_int[4], + mac_as_int[5]); +} + +bool NetworkProperties::OrderByType(const NetworkProperties& l, + const NetworkProperties& r) { + if (l.connection_state != r.connection_state) + return l.connection_state < r.connection_state; + // This sorting order is needed only for browser_tests, which expect this + // network type sort order: ethernet < wifi < vpn < cellular. + if (l.type == r.type) + return l.guid < r.guid; + if (l.type == onc::network_type::kEthernet) + return true; + if (r.type == onc::network_type::kEthernet) + return false; + return l.type > r.type; +} + +} // namespace wifi |