aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Server.Implementations/Connect/ConnectEntryPoint.cs
diff options
context:
space:
mode:
authorLuke <luke.pulverenti@gmail.com>2015-06-15 00:28:29 -0400
committerLuke <luke.pulverenti@gmail.com>2015-06-15 00:28:29 -0400
commit7d9d57a36ecee8e8a74b92544166c8fe70a0f880 (patch)
treea7f8a6bdb038048449d45a1e8926843015886f97 /MediaBrowser.Server.Implementations/Connect/ConnectEntryPoint.cs
parent5aafbe3dd694813a4e68f21ee72e59d6c53e776a (diff)
parent55eb54cbc28e40254a50c5a25443e910798243dc (diff)
Merge pull request #1118 from MediaBrowser/dev
3.0.5641.4
Diffstat (limited to 'MediaBrowser.Server.Implementations/Connect/ConnectEntryPoint.cs')
-rw-r--r--MediaBrowser.Server.Implementations/Connect/ConnectEntryPoint.cs56
1 files changed, 39 insertions, 17 deletions
diff --git a/MediaBrowser.Server.Implementations/Connect/ConnectEntryPoint.cs b/MediaBrowser.Server.Implementations/Connect/ConnectEntryPoint.cs
index 52ec5c9b1..973519a77 100644
--- a/MediaBrowser.Server.Implementations/Connect/ConnectEntryPoint.cs
+++ b/MediaBrowser.Server.Implementations/Connect/ConnectEntryPoint.cs
@@ -1,8 +1,10 @@
-using MediaBrowser.Common.Configuration;
+using MediaBrowser.Common;
+using MediaBrowser.Common.Configuration;
using MediaBrowser.Common.Net;
using MediaBrowser.Controller.Connect;
using MediaBrowser.Controller.Plugins;
using MediaBrowser.Model.Logging;
+using MediaBrowser.Model.Net;
using System;
using System.IO;
using System.Net;
@@ -20,14 +22,16 @@ namespace MediaBrowser.Server.Implementations.Connect
private readonly IConnectManager _connectManager;
private readonly INetworkManager _networkManager;
+ private readonly IApplicationHost _appHost;
- public ConnectEntryPoint(IHttpClient httpClient, IApplicationPaths appPaths, ILogger logger, INetworkManager networkManager, IConnectManager connectManager)
+ public ConnectEntryPoint(IHttpClient httpClient, IApplicationPaths appPaths, ILogger logger, INetworkManager networkManager, IConnectManager connectManager, IApplicationHost appHost)
{
_httpClient = httpClient;
_appPaths = appPaths;
_logger = logger;
_networkManager = networkManager;
_connectManager = connectManager;
+ _appHost = appHost;
}
public void Run()
@@ -37,30 +41,41 @@ namespace MediaBrowser.Server.Implementations.Connect
_timer = new Timer(TimerCallback, null, TimeSpan.FromSeconds(5), TimeSpan.FromHours(3));
}
+ private readonly string[] _ipLookups = { "http://bot.whatismyipaddress.com", "https://connect.mediabrowser.tv/service/ip" };
+
private async void TimerCallback(object state)
{
- try
+ foreach (var ipLookupUrl in _ipLookups)
{
- using (var stream = await _httpClient.Get(new HttpRequestOptions
- {
- Url = "http://bot.whatismyipaddress.com/"
-
- }).ConfigureAwait(false))
+ try
{
- using (var reader = new StreamReader(stream))
+ using (var stream = await _httpClient.Get(new HttpRequestOptions
{
- var address = await reader.ReadToEndAsync().ConfigureAwait(false);
+ Url = ipLookupUrl,
+ UserAgent = "Emby Server/" + _appHost.ApplicationVersion
- if (IsValid(address))
+ }).ConfigureAwait(false))
+ {
+ using (var reader = new StreamReader(stream))
{
- ((ConnectManager) _connectManager).OnWanAddressResolved(address);
- CacheAddress(address);
+ var address = await reader.ReadToEndAsync().ConfigureAwait(false);
+
+ if (IsValid(address))
+ {
+ ((ConnectManager)_connectManager).OnWanAddressResolved(address);
+ CacheAddress(address);
+ return;
+ }
}
}
}
- }
- catch
- {
+ catch (HttpException)
+ {
+ }
+ catch (Exception ex)
+ {
+ _logger.ErrorException("Error getting connection info", ex);
+ }
}
}
@@ -110,7 +125,14 @@ namespace MediaBrowser.Server.Implementations.Connect
private bool IsValid(string address)
{
IPAddress ipAddress;
- return IPAddress.TryParse(address, out ipAddress);
+ var valid = IPAddress.TryParse(address, out ipAddress);
+
+ if (!valid)
+ {
+ _logger.Error("{0} is not a valid ip address", address);
+ }
+
+ return valid;
}
public void Dispose()