summaryrefslogtreecommitdiffstats
path: root/components/wifi/network_properties.cc
diff options
context:
space:
mode:
authornoamsml@chromium.org <noamsml@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-06-04 08:41:22 +0000
committernoamsml@chromium.org <noamsml@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-06-04 08:41:22 +0000
commitca11059ee2dd9abe0c64b47cda1f58d6c662e855 (patch)
tree16daa9bbc8d59d1f9f9c9affb9ea28f487918431 /components/wifi/network_properties.cc
parenta4af7d5f79be09c03b36d86964500195aec4fc70 (diff)
downloadchromium_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.cc121
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