update ulna interface binding

This commit is contained in:
Luke 2015-12-25 22:23:02 -05:00
parent dff283a321
commit 0ffc5ebace
5 changed files with 111 additions and 86 deletions

View File

@ -7,6 +7,7 @@ using System.Net;
using System.Net.NetworkInformation; using System.Net.NetworkInformation;
using System.Net.Sockets; using System.Net.Sockets;
using System.Threading; using System.Threading;
using MoreLinq;
namespace MediaBrowser.Common.Implementations.Networking namespace MediaBrowser.Common.Implementations.Networking
{ {
@ -31,14 +32,14 @@ namespace MediaBrowser.Common.Implementations.Networking
} }
} }
private volatile List<string> _localIpAddresses; private volatile List<IPAddress> _localIpAddresses;
private readonly object _localIpAddressSyncLock = new object(); private readonly object _localIpAddressSyncLock = new object();
/// <summary> /// <summary>
/// Gets the machine's local ip address /// Gets the machine's local ip address
/// </summary> /// </summary>
/// <returns>IPAddress.</returns> /// <returns>IPAddress.</returns>
public IEnumerable<string> GetLocalIpAddresses() public IEnumerable<IPAddress> GetLocalIpAddresses()
{ {
if (_localIpAddresses == null) if (_localIpAddresses == null)
{ {
@ -58,25 +59,24 @@ namespace MediaBrowser.Common.Implementations.Networking
return _localIpAddresses; return _localIpAddresses;
} }
private IEnumerable<string> GetLocalIpAddressesInternal() private IEnumerable<IPAddress> GetLocalIpAddressesInternal()
{ {
var list = GetIPsDefault() var list = GetIPsDefault()
.Where(i => !IPAddress.IsLoopback(i))
.Select(i => i.ToString())
.Where(FilterIpAddress)
.ToList(); .ToList();
if (list.Count > 0) if (list.Count == 0)
{ {
return list; list.AddRange(GetLocalIpAddressesFallback());
} }
return GetLocalIpAddressesFallback().Where(FilterIpAddress); return list.Where(i => !IPAddress.IsLoopback(i)).Where(FilterIpAddress).DistinctBy(i => i.ToString());
} }
private bool FilterIpAddress(string address) private bool FilterIpAddress(IPAddress address)
{ {
if (address.StartsWith("169.", StringComparison.OrdinalIgnoreCase)) var addressString = address.ToString ();
if (addressString.StartsWith("169.", StringComparison.OrdinalIgnoreCase))
{ {
return false; return false;
} }
@ -164,8 +164,7 @@ namespace MediaBrowser.Common.Implementations.Networking
{ {
var prefix = addressString.Substring(0, lengthMatch); var prefix = addressString.Substring(0, lengthMatch);
if (GetLocalIpAddresses() if (GetLocalIpAddresses().Any(i => i.ToString().StartsWith(prefix, StringComparison.OrdinalIgnoreCase)))
.Any(i => i.StartsWith(prefix, StringComparison.OrdinalIgnoreCase)))
{ {
return true; return true;
} }
@ -209,33 +208,47 @@ namespace MediaBrowser.Common.Implementations.Networking
return Dns.GetHostAddresses(hostName); return Dns.GetHostAddresses(hostName);
} }
private IEnumerable<IPAddress> GetIPsDefault() private List<IPAddress> GetIPsDefault()
{ {
foreach (var adapter in NetworkInterface.GetAllNetworkInterfaces()) NetworkInterface[] interfaces;
{
var props = adapter.GetIPProperties();
var gateways = from ga in props.GatewayAddresses
where !ga.Address.Equals(IPAddress.Any)
select true;
if (!gateways.Any()) try
{ {
continue; interfaces = NetworkInterface.GetAllNetworkInterfaces();
}
catch (Exception ex)
{
Logger.ErrorException("Error in GetAllNetworkInterfaces", ex);
return new List<IPAddress>();
} }
foreach (var uni in props.UnicastAddresses) return interfaces.SelectMany(network => {
try
{ {
var address = uni.Address; Logger.Debug("Found interface: {0}. Type: {1}. Status: {2}", network.Name, network.NetworkInterfaceType, network.OperationalStatus);
if (address.AddressFamily != AddressFamily.InterNetwork)
var properties = network.GetIPProperties();
var ipV4 = properties.GetIPv4Properties();
if (null == ipV4)
return new List<IPAddress>();
return properties.UnicastAddresses
.Where(i => i.Address.AddressFamily == AddressFamily.InterNetwork && !IPAddress.IsLoopback(i.Address))
.Select(i => i.Address)
.ToList();
}
catch (Exception ex)
{ {
continue; Logger.ErrorException("Error querying network interface", ex);
} return new List<IPAddress>();
yield return address;
}
}
} }
private IEnumerable<string> GetLocalIpAddressesFallback() }).DistinctBy(i => i.ToString())
.ToList();
}
private IEnumerable<IPAddress> GetLocalIpAddressesFallback()
{ {
var host = Dns.GetHostEntry(Dns.GetHostName()); var host = Dns.GetHostEntry(Dns.GetHostName());
@ -243,7 +256,6 @@ namespace MediaBrowser.Common.Implementations.Networking
// It's not fool-proof so ultimately the consumer will have to examine them and decide // It's not fool-proof so ultimately the consumer will have to examine them and decide
return host.AddressList return host.AddressList
.Where(i => i.AddressFamily == AddressFamily.InterNetwork) .Where(i => i.AddressFamily == AddressFamily.InterNetwork)
.Select(i => i.ToString())
.Reverse(); .Reverse();
} }

View File

@ -11,7 +11,7 @@ namespace MediaBrowser.Common.Net
/// Gets the machine's local ip address /// Gets the machine's local ip address
/// </summary> /// </summary>
/// <returns>IPAddress.</returns> /// <returns>IPAddress.</returns>
IEnumerable<string> GetLocalIpAddresses(); IEnumerable<IPAddress> GetLocalIpAddresses();
/// <summary> /// <summary>
/// Gets a random port number that is currently available /// Gets a random port number that is currently available

View File

@ -150,11 +150,12 @@ namespace MediaBrowser.Dlna.Main
{ {
foreach (var address in _network.GetLocalIpAddresses()) foreach (var address in _network.GetLocalIpAddresses())
{ {
var guid = address.GetMD5(); var addressString = address.ToString ();
var guid = addressString.GetMD5();
var descriptorURI = "/dlna/" + guid.ToString("N") + "/description.xml"; var descriptorURI = "/dlna/" + guid.ToString("N") + "/description.xml";
var uri = new Uri(_appHost.GetLocalApiUrl(address) + descriptorURI); var uri = new Uri(_appHost.GetLocalApiUrl(addressString) + descriptorURI);
var services = new List<string> var services = new List<string>
{ {
@ -166,7 +167,7 @@ namespace MediaBrowser.Dlna.Main
"uuid:" + guid.ToString("N") "uuid:" + guid.ToString("N")
}; };
_ssdpHandler.RegisterNotification(guid, uri, IPAddress.Parse(address), services); _ssdpHandler.RegisterNotification(guid, uri, address, services);
_registeredServerIds.Add(guid.ToString("N")); _registeredServerIds.Add(guid.ToString("N"));
} }

View File

@ -36,29 +36,53 @@ namespace MediaBrowser.Dlna.Ssdp
_appHost = appHost; _appHost = appHost;
} }
private List<IPAddress> GetLocalIpAddresses()
{
NetworkInterface[] interfaces;
try
{
interfaces = NetworkInterface.GetAllNetworkInterfaces();
}
catch (Exception ex)
{
_logger.ErrorException("Error in GetAllNetworkInterfaces", ex);
return new List<IPAddress>();
}
return interfaces.SelectMany(network => {
try
{
_logger.Debug("Found interface: {0}. Type: {1}. Status: {2}", network.Name, network.NetworkInterfaceType, network.OperationalStatus);
var properties = network.GetIPProperties();
var ipV4 = properties.GetIPv4Properties();
if (null == ipV4)
return new List<IPAddress>();
return properties.UnicastAddresses
.Where(i => i.Address.AddressFamily == AddressFamily.InterNetwork && !IPAddress.IsLoopback(i.Address))
.Select(i => i.Address)
.ToList();
}
catch (Exception ex)
{
_logger.ErrorException("Error querying network interface", ex);
return new List<IPAddress>();
}
})
.Distinct()
.ToList();
}
public void Start(SsdpHandler ssdpHandler) public void Start(SsdpHandler ssdpHandler)
{ {
_ssdpHandler = ssdpHandler; _ssdpHandler = ssdpHandler;
_ssdpHandler.MessageReceived += _ssdpHandler_MessageReceived; _ssdpHandler.MessageReceived += _ssdpHandler_MessageReceived;
foreach (var network in GetNetworkInterfaces()) foreach (var localIp in GetLocalIpAddresses())
{
_logger.Debug("Found interface: {0}. Type: {1}. Status: {2}", network.Name, network.NetworkInterfaceType, network.OperationalStatus);
if (!network.SupportsMulticast || OperationalStatus.Up != network.OperationalStatus || !network.GetIPProperties().MulticastAddresses.Any())
continue;
var properties = network.GetIPProperties();
var ipV4 = properties.GetIPv4Properties();
if (null == ipV4)
continue;
var localIps = properties.UnicastAddresses
.Where(i => i.Address.AddressFamily == AddressFamily.InterNetwork)
.Select(i => i.Address)
.ToList();
foreach (var localIp in localIps)
{ {
try try
{ {
@ -70,7 +94,6 @@ namespace MediaBrowser.Dlna.Ssdp
} }
} }
} }
}
void _ssdpHandler_MessageReceived(object sender, SsdpMessageEventArgs e) void _ssdpHandler_MessageReceived(object sender, SsdpMessageEventArgs e)
{ {
@ -107,30 +130,18 @@ namespace MediaBrowser.Dlna.Ssdp
} }
} }
private IEnumerable<NetworkInterface> GetNetworkInterfaces()
{
try
{
return NetworkInterface.GetAllNetworkInterfaces();
}
catch (Exception ex)
{
_logger.ErrorException("Error in GetAllNetworkInterfaces", ex);
return new List<NetworkInterface>();
}
}
private void CreateListener(IPAddress localIp) private void CreateListener(IPAddress localIp)
{ {
Task.Factory.StartNew(async (o) => Task.Factory.StartNew(async (o) =>
{ {
try try
{ {
_logger.Info("Creating SSDP listener on {0}", localIp);
var endPoint = new IPEndPoint(localIp, 1900); var endPoint = new IPEndPoint(localIp, 1900);
var socket = GetMulticastSocket(localIp, endPoint); var socket = GetMulticastSocket(localIp, endPoint);
_logger.Info("Creating SSDP listener on {0}", localIp);
var receiveBuffer = new byte[64000]; var receiveBuffer = new byte[64000];
CreateNotifier(localIp); CreateNotifier(localIp);

View File

@ -1154,6 +1154,7 @@ namespace MediaBrowser.Server.Startup.Common
get get
{ {
var localAddresses = NetworkManager.GetLocalIpAddresses() var localAddresses = NetworkManager.GetLocalIpAddresses()
.Select(i => i.ToString())
.ToList(); .ToList();
var httpServerAddresses = HttpServer.LocalEndPoints var httpServerAddresses = HttpServer.LocalEndPoints