title | author | ms.author | ms.date | ms.topic | description | keywords |
---|---|---|---|---|---|---|
Internet Connection Sharing |
derekameer |
demeer |
08/28/2017 |
article |
Learn how to enable and configure internet connection sharing on Windows IoT Core. |
windows iot, Internet Connection Sharing, ICS, Device Portal |
This document describes how internet connection sharing (ICS) can be enabled on Windows IoT Core. Developers can use the NetworkTetheringManager API to configure ICS programmatically. The API is described in the NetworkOperatorTetheringManager class. When using one of the Windows 10 IoT Core Release Image ICS can also be configured using the device portal.
For the Sharing Tutorial, please view the Windows IoT Core November 2015 Release document.
See documentation on Windows Device Portal (WDP).
The code sample below demonstrates how the NetworkOperatorTetheringManager API is used to start sharing an Ethernet connection over Wi-Fi. The CreateFromConnectionProfile method accepts arguments that specifies the public and private interface. In any cases of misconfiguration, such as the Wi-Fi radio is turned off, or Ethernet has limited connectivity, then the attempt to start internet sharing conveys an appropriate error code pertaining to this scenario.
using Windows.Networking.NetworkOperators;
using Windows.Networking.Connectivity;
// Find the Ethernet profile
var connectionProfiles = NetworkInformation.GetConnectionProfiles();
var ethernetConnectionProfile = connectionProfiles.FirstOrDefault(x => x.IsEthernetConnectionProfile);
// Find an 802.11 wireless network interface (IANA Type 71)
var networkAdapters = NetworkInformation.GetNetworkAdapters();
var targetNetworkAdapter = networkAdapters.FirstOrDefault(x => x.IanaInterfaceType == 71);
if (ethernetConnectionProfile != null && targetNetworkAdapter != null)
{
var tetheringManager = NetworkOperatorTetheringManager.CreateFromConnectionProfile(ethernetConnectionProfile, targetNetworkAdapter);
var result = await tetheringManager.StartTetheringAsync();
if (result.Status == TetheringOperationStatus.Success)
{
UpdateUI();
}
else
{
ProcessTetheringError(result);
}
}