aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Common.Implementations/Networking/BaseNetworkManager.cs
diff options
context:
space:
mode:
authorLuke Pulverenti <luke.pulverenti@gmail.com>2014-09-23 21:44:05 -0400
committerLuke Pulverenti <luke.pulverenti@gmail.com>2014-09-23 21:44:05 -0400
commit995353e21671b08838064f77c4bae5382d0bbf83 (patch)
tree8dcdaca47a2102509ac9ad0d83dbc37ebbe7d264 /MediaBrowser.Common.Implementations/Networking/BaseNetworkManager.cs
parentdbb8ec192f90ce0a61b5c7d64ecd73bb8dcb4101 (diff)
add dish hopper profile
Diffstat (limited to 'MediaBrowser.Common.Implementations/Networking/BaseNetworkManager.cs')
-rw-r--r--MediaBrowser.Common.Implementations/Networking/BaseNetworkManager.cs67
1 files changed, 27 insertions, 40 deletions
diff --git a/MediaBrowser.Common.Implementations/Networking/BaseNetworkManager.cs b/MediaBrowser.Common.Implementations/Networking/BaseNetworkManager.cs
index 46f880657..2a1c5dfe6 100644
--- a/MediaBrowser.Common.Implementations/Networking/BaseNetworkManager.cs
+++ b/MediaBrowser.Common.Implementations/Networking/BaseNetworkManager.cs
@@ -24,32 +24,32 @@ namespace MediaBrowser.Common.Implementations.Networking
/// <returns>IPAddress.</returns>
public IEnumerable<string> GetLocalIpAddresses()
{
- var list = GetIPsDefault()
- .Where(i => !IPAddress.IsLoopback(i))
- .Select(i => i.ToString())
- .ToList();
+ var list = GetIPsDefault().Where(i => !IPAddress.IsLoopback(i)).Select(i => i.ToString()).ToList();
- try
+ if (list.Count > 0)
{
- var listFromDns = Dns.GetHostAddresses(Dns.GetHostName())
- .Where(i => i.AddressFamily == AddressFamily.InterNetwork)
- .Where(i => !IPAddress.IsLoopback(i))
- .Select(i => i.ToString())
- .ToList();
-
- if (listFromDns.Count > 0)
- {
- return listFromDns
- .OrderBy(i => (list.Contains(i, StringComparer.OrdinalIgnoreCase) ? 0 : 1))
- .ToList();
- }
+ return list;
}
- catch
- {
- }
-
- return list;
+ return GetLocalIpAddressesFallback();
+ }
+
+ private bool IsInPrivateAddressSpace(string endpoint)
+ {
+ // Private address space:
+ // http://en.wikipedia.org/wiki/Private_network
+
+ return
+
+ // If url was requested with computer name, we may see this
+ endpoint.IndexOf("::", StringComparison.OrdinalIgnoreCase) != -1 ||
+
+ endpoint.StartsWith("localhost", StringComparison.OrdinalIgnoreCase) ||
+ endpoint.StartsWith("127.", StringComparison.OrdinalIgnoreCase) ||
+ endpoint.StartsWith("10.", StringComparison.OrdinalIgnoreCase) ||
+ endpoint.StartsWith("192.", StringComparison.OrdinalIgnoreCase) ||
+ endpoint.StartsWith("172.", StringComparison.OrdinalIgnoreCase) ||
+ endpoint.StartsWith("169.", StringComparison.OrdinalIgnoreCase);
}
public bool IsInLocalNetwork(string endpoint)
@@ -64,6 +64,11 @@ namespace MediaBrowser.Common.Implementations.Networking
throw new ArgumentNullException("endpoint");
}
+ if (IsInPrivateAddressSpace(endpoint))
+ {
+ return true;
+ }
+
const int lengthMatch = 4;
if (endpoint.Length >= lengthMatch)
@@ -77,24 +82,6 @@ namespace MediaBrowser.Common.Implementations.Networking
}
}
- // Private address space:
- // http://en.wikipedia.org/wiki/Private_network
-
- var isPrivate =
-
- // If url was requested with computer name, we may see this
- endpoint.IndexOf("::", StringComparison.OrdinalIgnoreCase) != -1 ||
-
- endpoint.StartsWith("10.", StringComparison.OrdinalIgnoreCase) ||
- endpoint.StartsWith("192.", StringComparison.OrdinalIgnoreCase) ||
- endpoint.StartsWith("172.", StringComparison.OrdinalIgnoreCase) ||
- endpoint.StartsWith("169.", StringComparison.OrdinalIgnoreCase);
-
- if (isPrivate)
- {
- return true;
- }
-
IPAddress address;
if (resolveHost && !IPAddress.TryParse(endpoint, out address))
{