Index: net/nqe/network_id.h |
diff --git a/net/nqe/network_id.h b/net/nqe/network_id.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..46662f68c0e2191622b27ae28c145bc846891b15 |
--- /dev/null |
+++ b/net/nqe/network_id.h |
@@ -0,0 +1,63 @@ |
+// Copyright 2016 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. |
+ |
+#ifndef NET_NQE_NETWORK_ID_H_ |
+#define NET_NQE_NETWORK_ID_H_ |
+ |
+#include <string> |
+#include <tuple> |
+ |
+#include "net/base/net_export.h" |
+#include "net/base/network_change_notifier.h" |
+ |
+namespace net { |
+ |
Alexei Svitkine (slow)
2016/07/25 15:33:27
Optional nit: I think it's fine to omit newlines b
tbansal1
2016/07/25 17:22:37
Done.
|
+namespace nqe { |
+ |
+namespace internal { |
+ |
+// NetworkID is used to uniquely identify a network. |
+// For the purpose of network quality estimation and caching, a network is |
+// uniquely identified by a combination of |type| and |
+// |id|. This approach is unable to distinguish networks with |
+// same name (e.g., different Wi-Fi networks with same SSID). |
+// This is a protected member to expose it to tests. |
+struct NET_EXPORT_PRIVATE NetworkID { |
+ NetworkID(NetworkChangeNotifier::ConnectionType type, const std::string& id) |
+ : type(type), id(id) {} |
+ NetworkID(const NetworkID& other) : type(other.type), id(other.id) {} |
+ ~NetworkID() {} |
+ |
+ NetworkID& operator=(const NetworkID& other) { |
+ type = other.type; |
+ id = other.id; |
+ return *this; |
+ } |
+ |
+ // Overloaded to support ordered collections. |
+ bool operator<(const NetworkID& other) const { |
+ return std::tie(type, id) < std::tie(other.type, other.id); |
+ } |
+ |
+ // Connection type of the network. |
+ NetworkChangeNotifier::ConnectionType type; |
+ |
+ // Name of this network. This is set to: |
+ // - Wi-Fi SSID if the device is connected to a Wi-Fi access point and the |
+ // SSID name is available, or |
+ // - MCC/MNC code of the cellular carrier if the device is connected to a |
+ // cellular network, or |
+ // - "Ethernet" in case the device is connected to ethernet. |
+ // - An empty string in all other cases or if the network name is not |
+ // exposed by platform APIs. |
+ std::string id; |
+}; |
+ |
+} // namespace internal |
+ |
+} // namespace nqe |
+ |
+} // namespace net |
+ |
+#endif // NET_NQE_NETWORK_QUALITY_ESTIMATOR_H_ |