Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(189)

Unified Diff: net/base/net_util_win.cc

Issue 992733002: Remove //net (except for Android test stuff) and sdch (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « net/base/net_util_win.h ('k') | net/base/network_activity_monitor.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/base/net_util_win.cc
diff --git a/net/base/net_util_win.cc b/net/base/net_util_win.cc
deleted file mode 100644
index 6658358e4e047927cb5c72ce1f8a8192a2de5171..0000000000000000000000000000000000000000
--- a/net/base/net_util_win.cc
+++ /dev/null
@@ -1,328 +0,0 @@
-// Copyright (c) 2012 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 "net/base/net_util.h"
-
-#include <iphlpapi.h>
-#include <wlanapi.h>
-
-#include <algorithm>
-
-#include "base/files/file_path.h"
-#include "base/lazy_instance.h"
-#include "base/memory/scoped_ptr.h"
-#include "base/strings/string_piece.h"
-#include "base/strings/string_util.h"
-#include "base/strings/sys_string_conversions.h"
-#include "base/strings/utf_string_conversions.h"
-#include "base/threading/thread_restrictions.h"
-#include "base/win/scoped_handle.h"
-#include "base/win/windows_version.h"
-#include "net/base/escape.h"
-#include "net/base/ip_endpoint.h"
-#include "net/base/net_errors.h"
-#include "net/base/net_util_win.h"
-#include "url/gurl.h"
-
-namespace net {
-
-namespace {
-
-// Converts Windows defined types to NetworkInterfaceType.
-NetworkChangeNotifier::ConnectionType GetNetworkInterfaceType(DWORD ifType) {
- // Bail out for pre-Vista versions of Windows which are documented to give
- // inaccurate results like returning Ethernet for WiFi.
- // http://msdn.microsoft.com/en-us/library/windows/desktop/aa366058.aspx
- if (base::win::GetVersion() < base::win::VERSION_VISTA)
- return NetworkChangeNotifier::CONNECTION_UNKNOWN;
-
- NetworkChangeNotifier::ConnectionType type =
- NetworkChangeNotifier::CONNECTION_UNKNOWN;
- if (ifType == IF_TYPE_ETHERNET_CSMACD) {
- type = NetworkChangeNotifier::CONNECTION_ETHERNET;
- } else if (ifType == IF_TYPE_IEEE80211) {
- type = NetworkChangeNotifier::CONNECTION_WIFI;
- }
- // TODO(mallinath) - Cellular?
- return type;
-}
-
-} // namespace
-
-namespace internal {
-
-base::LazyInstance<WlanApi>::Leaky lazy_wlanapi =
- LAZY_INSTANCE_INITIALIZER;
-
-WlanApi& WlanApi::GetInstance() {
- return lazy_wlanapi.Get();
-}
-
-WlanApi::WlanApi() : initialized(false) {
- // Use an absolute path to load the DLL to avoid DLL preloading attacks.
- static const wchar_t* const kDLL = L"%WINDIR%\\system32\\wlanapi.dll";
- wchar_t path[MAX_PATH] = {0};
- ExpandEnvironmentStrings(kDLL, path, arraysize(path));
- module = ::LoadLibraryEx(path, NULL, LOAD_WITH_ALTERED_SEARCH_PATH);
- if (!module)
- return;
-
- open_handle_func = reinterpret_cast<WlanOpenHandleFunc>(
- ::GetProcAddress(module, "WlanOpenHandle"));
- enum_interfaces_func = reinterpret_cast<WlanEnumInterfacesFunc>(
- ::GetProcAddress(module, "WlanEnumInterfaces"));
- query_interface_func = reinterpret_cast<WlanQueryInterfaceFunc>(
- ::GetProcAddress(module, "WlanQueryInterface"));
- set_interface_func = reinterpret_cast<WlanSetInterfaceFunc>(
- ::GetProcAddress(module, "WlanSetInterface"));
- free_memory_func = reinterpret_cast<WlanFreeMemoryFunc>(
- ::GetProcAddress(module, "WlanFreeMemory"));
- close_handle_func = reinterpret_cast<WlanCloseHandleFunc>(
- ::GetProcAddress(module, "WlanCloseHandle"));
- initialized = open_handle_func && enum_interfaces_func &&
- query_interface_func && set_interface_func &&
- free_memory_func && close_handle_func;
-}
-
-bool GetNetworkListImpl(NetworkInterfaceList* networks,
- int policy,
- bool is_xp,
- const IP_ADAPTER_ADDRESSES* adapters) {
- for (const IP_ADAPTER_ADDRESSES* adapter = adapters; adapter != NULL;
- adapter = adapter->Next) {
- // Ignore the loopback device.
- if (adapter->IfType == IF_TYPE_SOFTWARE_LOOPBACK) {
- continue;
- }
-
- if (adapter->OperStatus != IfOperStatusUp) {
- continue;
- }
-
- // Ignore any HOST side vmware adapters with a description like:
- // VMware Virtual Ethernet Adapter for VMnet1
- // but don't ignore any GUEST side adapters with a description like:
- // VMware Accelerated AMD PCNet Adapter #2
- if ((policy & EXCLUDE_HOST_SCOPE_VIRTUAL_INTERFACES) &&
- strstr(adapter->AdapterName, "VMnet") != NULL) {
- continue;
- }
-
- for (IP_ADAPTER_UNICAST_ADDRESS* address = adapter->FirstUnicastAddress;
- address; address = address->Next) {
- int family = address->Address.lpSockaddr->sa_family;
- if (family == AF_INET || family == AF_INET6) {
- IPEndPoint endpoint;
- if (endpoint.FromSockAddr(address->Address.lpSockaddr,
- address->Address.iSockaddrLength)) {
- // XP has no OnLinkPrefixLength field.
- size_t prefix_length = is_xp ? 0 : address->OnLinkPrefixLength;
- if (is_xp) {
- // Prior to Windows Vista the FirstPrefix pointed to the list with
- // single prefix for each IP address assigned to the adapter.
- // Order of FirstPrefix does not match order of FirstUnicastAddress,
- // so we need to find corresponding prefix.
- for (IP_ADAPTER_PREFIX* prefix = adapter->FirstPrefix; prefix;
- prefix = prefix->Next) {
- int prefix_family = prefix->Address.lpSockaddr->sa_family;
- IPEndPoint network_endpoint;
- if (prefix_family == family &&
- network_endpoint.FromSockAddr(prefix->Address.lpSockaddr,
- prefix->Address.iSockaddrLength) &&
- IPNumberMatchesPrefix(endpoint.address(),
- network_endpoint.address(),
- prefix->PrefixLength)) {
- prefix_length =
- std::max<size_t>(prefix_length, prefix->PrefixLength);
- }
- }
- }
-
- // If the duplicate address detection (DAD) state is not changed to
- // Preferred, skip this address.
- if (address->DadState != IpDadStatePreferred) {
- continue;
- }
-
- uint32 index =
- (family == AF_INET) ? adapter->IfIndex : adapter->Ipv6IfIndex;
-
- // From http://technet.microsoft.com/en-us/ff568768(v=vs.60).aspx, the
- // way to identify a temporary IPv6 Address is to check if
- // PrefixOrigin is equal to IpPrefixOriginRouterAdvertisement and
- // SuffixOrigin equal to IpSuffixOriginRandom.
- int ip_address_attributes = IP_ADDRESS_ATTRIBUTE_NONE;
- if (family == AF_INET6) {
- if (address->PrefixOrigin == IpPrefixOriginRouterAdvertisement &&
- address->SuffixOrigin == IpSuffixOriginRandom) {
- ip_address_attributes |= IP_ADDRESS_ATTRIBUTE_TEMPORARY;
- }
- if (address->PreferredLifetime == 0) {
- ip_address_attributes |= IP_ADDRESS_ATTRIBUTE_DEPRECATED;
- }
- }
- networks->push_back(NetworkInterface(
- adapter->AdapterName,
- base::SysWideToNativeMB(adapter->FriendlyName), index,
- GetNetworkInterfaceType(adapter->IfType), endpoint.address(),
- prefix_length, ip_address_attributes));
- }
- }
- }
- }
- return true;
-}
-
-} // namespace internal
-
-bool GetNetworkList(NetworkInterfaceList* networks, int policy) {
- bool is_xp = base::win::GetVersion() < base::win::VERSION_VISTA;
- ULONG len = 0;
- ULONG flags = is_xp ? GAA_FLAG_INCLUDE_PREFIX : 0;
- // GetAdaptersAddresses() may require IO operations.
- base::ThreadRestrictions::AssertIOAllowed();
- ULONG result = GetAdaptersAddresses(AF_UNSPEC, flags, NULL, NULL, &len);
- if (result != ERROR_BUFFER_OVERFLOW) {
- // There are 0 networks.
- return true;
- }
- scoped_ptr<char[]> buf(new char[len]);
- IP_ADAPTER_ADDRESSES* adapters =
- reinterpret_cast<IP_ADAPTER_ADDRESSES*>(buf.get());
- result = GetAdaptersAddresses(AF_UNSPEC, flags, NULL, adapters, &len);
- if (result != NO_ERROR) {
- LOG(ERROR) << "GetAdaptersAddresses failed: " << result;
- return false;
- }
-
- return internal::GetNetworkListImpl(networks, policy, is_xp, adapters);
-}
-
-WifiPHYLayerProtocol GetWifiPHYLayerProtocol() {
- const internal::WlanApi& wlanapi = internal::WlanApi::GetInstance();
- if (!wlanapi.initialized)
- return WIFI_PHY_LAYER_PROTOCOL_NONE;
-
- internal::WlanHandle client;
- DWORD cur_version = 0;
- const DWORD kMaxClientVersion = 2;
- DWORD result = wlanapi.OpenHandle(kMaxClientVersion, &cur_version, &client);
- if (result != ERROR_SUCCESS)
- return WIFI_PHY_LAYER_PROTOCOL_NONE;
-
- WLAN_INTERFACE_INFO_LIST* interface_list_ptr = NULL;
- result = wlanapi.enum_interfaces_func(client.Get(), NULL,
- &interface_list_ptr);
- if (result != ERROR_SUCCESS)
- return WIFI_PHY_LAYER_PROTOCOL_NONE;
- scoped_ptr<WLAN_INTERFACE_INFO_LIST, internal::WlanApiDeleter> interface_list(
- interface_list_ptr);
-
- // Assume at most one connected wifi interface.
- WLAN_INTERFACE_INFO* info = NULL;
- for (unsigned i = 0; i < interface_list->dwNumberOfItems; ++i) {
- if (interface_list->InterfaceInfo[i].isState ==
- wlan_interface_state_connected) {
- info = &interface_list->InterfaceInfo[i];
- break;
- }
- }
-
- if (info == NULL)
- return WIFI_PHY_LAYER_PROTOCOL_NONE;
-
- WLAN_CONNECTION_ATTRIBUTES* conn_info_ptr;
- DWORD conn_info_size = 0;
- WLAN_OPCODE_VALUE_TYPE op_code;
- result = wlanapi.query_interface_func(
- client.Get(), &info->InterfaceGuid, wlan_intf_opcode_current_connection,
- NULL, &conn_info_size, reinterpret_cast<VOID**>(&conn_info_ptr),
- &op_code);
- if (result != ERROR_SUCCESS)
- return WIFI_PHY_LAYER_PROTOCOL_UNKNOWN;
- scoped_ptr<WLAN_CONNECTION_ATTRIBUTES, internal::WlanApiDeleter> conn_info(
- conn_info_ptr);
-
- switch (conn_info->wlanAssociationAttributes.dot11PhyType) {
- case dot11_phy_type_fhss:
- return WIFI_PHY_LAYER_PROTOCOL_ANCIENT;
- case dot11_phy_type_dsss:
- return WIFI_PHY_LAYER_PROTOCOL_B;
- case dot11_phy_type_irbaseband:
- return WIFI_PHY_LAYER_PROTOCOL_ANCIENT;
- case dot11_phy_type_ofdm:
- return WIFI_PHY_LAYER_PROTOCOL_A;
- case dot11_phy_type_hrdsss:
- return WIFI_PHY_LAYER_PROTOCOL_B;
- case dot11_phy_type_erp:
- return WIFI_PHY_LAYER_PROTOCOL_G;
- case dot11_phy_type_ht:
- return WIFI_PHY_LAYER_PROTOCOL_N;
- default:
- return WIFI_PHY_LAYER_PROTOCOL_UNKNOWN;
- }
-}
-
-// Note: There is no need to explicitly set the options back
-// as the OS will automatically set them back when the WlanHandle
-// is closed.
-class WifiOptionSetter : public ScopedWifiOptions {
- public:
- WifiOptionSetter(int options) {
- const internal::WlanApi& wlanapi = internal::WlanApi::GetInstance();
- if (!wlanapi.initialized)
- return;
-
- DWORD cur_version = 0;
- const DWORD kMaxClientVersion = 2;
- DWORD result = wlanapi.OpenHandle(
- kMaxClientVersion, &cur_version, &client_);
- if (result != ERROR_SUCCESS)
- return;
-
- WLAN_INTERFACE_INFO_LIST* interface_list_ptr = NULL;
- result = wlanapi.enum_interfaces_func(client_.Get(), NULL,
- &interface_list_ptr);
- if (result != ERROR_SUCCESS)
- return;
- scoped_ptr<WLAN_INTERFACE_INFO_LIST, internal::WlanApiDeleter>
- interface_list(interface_list_ptr);
-
- for (unsigned i = 0; i < interface_list->dwNumberOfItems; ++i) {
- WLAN_INTERFACE_INFO* info = &interface_list->InterfaceInfo[i];
- if (options & WIFI_OPTIONS_DISABLE_SCAN) {
- BOOL data = false;
- wlanapi.set_interface_func(client_.Get(),
- &info->InterfaceGuid,
- wlan_intf_opcode_background_scan_enabled,
- sizeof(data),
- &data,
- NULL);
- }
- if (options & WIFI_OPTIONS_MEDIA_STREAMING_MODE) {
- BOOL data = true;
- wlanapi.set_interface_func(client_.Get(),
- &info->InterfaceGuid,
- wlan_intf_opcode_media_streaming_mode,
- sizeof(data),
- &data,
- NULL);
- }
- }
- }
-
- private:
- internal::WlanHandle client_;
-};
-
-scoped_ptr<ScopedWifiOptions> SetWifiOptions(int options) {
- return scoped_ptr<ScopedWifiOptions>(new WifiOptionSetter(options));
-}
-
-std::string GetWifiSSID() {
- NOTIMPLEMENTED();
- return "";
-}
-
-} // namespace net
« no previous file with comments | « net/base/net_util_win.h ('k') | net/base/network_activity_monitor.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698