| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 | 
							- 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.Text;
 
- using System.Threading.Tasks;
 
- using MediaBrowser.Model.IO;
 
- using MediaBrowser.Model.Threading;
 
- namespace Emby.Server.Implementations.Connect
 
- {
 
-     public class ConnectEntryPoint : IServerEntryPoint
 
-     {
 
-         private ITimer _timer;
 
-         private readonly IHttpClient _httpClient;
 
-         private readonly IApplicationPaths _appPaths;
 
-         private readonly ILogger _logger;
 
-         private readonly IConnectManager _connectManager;
 
-         private readonly INetworkManager _networkManager;
 
-         private readonly IApplicationHost _appHost;
 
-         private readonly IFileSystem _fileSystem;
 
-         private readonly ITimerFactory _timerFactory;
 
-         public ConnectEntryPoint(IHttpClient httpClient, IApplicationPaths appPaths, ILogger logger, INetworkManager networkManager, IConnectManager connectManager, IApplicationHost appHost, IFileSystem fileSystem, ITimerFactory timerFactory)
 
-         {
 
-             _httpClient = httpClient;
 
-             _appPaths = appPaths;
 
-             _logger = logger;
 
-             _networkManager = networkManager;
 
-             _connectManager = connectManager;
 
-             _appHost = appHost;
 
-             _fileSystem = fileSystem;
 
-             _timerFactory = timerFactory;
 
-         }
 
-         public void Run()
 
-         {
 
-             LoadCachedAddress();
 
-             _timer = _timerFactory.Create(TimerCallback, null, TimeSpan.FromSeconds(5), TimeSpan.FromHours(1));
 
-             ((ConnectManager)_connectManager).Start();
 
-         }
 
-         private readonly string[] _ipLookups =
 
-         {
 
-             "http://bot.whatismyipaddress.com",
 
-             "https://connect.emby.media/service/ip"
 
-         };
 
-         private async void TimerCallback(object state)
 
-         {
 
-             IpAddressInfo validIpAddress = null;
 
-             foreach (var ipLookupUrl in _ipLookups)
 
-             {
 
-                 try
 
-                 {
 
-                     validIpAddress = await GetIpAddress(ipLookupUrl).ConfigureAwait(false);
 
-                     // Try to find the ipv4 address, if present
 
-                     if (validIpAddress.AddressFamily != IpAddressFamily.InterNetworkV6)
 
-                     {
 
-                         break;
 
-                     }
 
-                 }
 
-                 catch (HttpException)
 
-                 {
 
-                 }
 
-                 catch (Exception ex)
 
-                 {
 
-                     _logger.ErrorException("Error getting connection info", ex);
 
-                 }
 
-             }
 
-            
 
-             // If this produced an ipv6 address, try again
 
-             if (validIpAddress != null && validIpAddress.AddressFamily == IpAddressFamily.InterNetworkV6)
 
-             {
 
-                 foreach (var ipLookupUrl in _ipLookups)
 
-                 {
 
-                     try
 
-                     {
 
-                         var newAddress = await GetIpAddress(ipLookupUrl, true).ConfigureAwait(false);
 
-                         // Try to find the ipv4 address, if present
 
-                         if (newAddress.AddressFamily != IpAddressFamily.InterNetworkV6)
 
-                         {
 
-                             validIpAddress = newAddress;
 
-                             break;
 
-                         }
 
-                     }
 
-                     catch (HttpException)
 
-                     {
 
-                     }
 
-                     catch (Exception ex)
 
-                     {
 
-                         _logger.ErrorException("Error getting connection info", ex);
 
-                     }
 
-                 }
 
-             }
 
-             if (validIpAddress != null)
 
-             {
 
-                 ((ConnectManager)_connectManager).OnWanAddressResolved(validIpAddress);
 
-                 CacheAddress(validIpAddress);
 
-             }
 
-         }
 
-         private async Task<IpAddressInfo> GetIpAddress(string lookupUrl, bool preferIpv4 = false)
 
-         {
 
-             // Sometimes whatismyipaddress might fail, but it won't do us any good having users raise alarms over it.
 
-             var logErrors = false;
 
- #if DEBUG
 
-             logErrors = true;
 
- #endif
 
-             using (var stream = await _httpClient.Get(new HttpRequestOptions
 
-             {
 
-                 Url = lookupUrl,
 
-                 UserAgent = "Emby/" + _appHost.ApplicationVersion,
 
-                 LogErrors = logErrors,
 
-                 // Seeing block length errors with our server
 
-                 EnableHttpCompression = false,
 
-                 PreferIpv4 = preferIpv4,
 
-                 BufferContent = false
 
-             }).ConfigureAwait(false))
 
-             {
 
-                 using (var reader = new StreamReader(stream))
 
-                 {
 
-                     var addressString = await reader.ReadToEndAsync().ConfigureAwait(false);
 
-                     return _networkManager.ParseIpAddress(addressString);
 
-                 }
 
-             }
 
-         }
 
-         private string CacheFilePath
 
-         {
 
-             get { return Path.Combine(_appPaths.DataPath, "wan.txt"); }
 
-         }
 
-         private void CacheAddress(IpAddressInfo address)
 
-         {
 
-             var path = CacheFilePath;
 
-             try
 
-             {
 
-                 _fileSystem.CreateDirectory(Path.GetDirectoryName(path));
 
-                 _fileSystem.WriteAllText(path, address.ToString(), Encoding.UTF8);
 
-             }
 
-             catch (Exception ex)
 
-             {
 
-                 _logger.ErrorException("Error saving data", ex);
 
-             }
 
-         }
 
-         private void LoadCachedAddress()
 
-         {
 
-             var path = CacheFilePath;
 
-             _logger.Info("Loading data from {0}", path);
 
-             try
 
-             {
 
-                 var endpoint = _fileSystem.ReadAllText(path, Encoding.UTF8);
 
-                 IpAddressInfo ipAddress;
 
-                 if (_networkManager.TryParseIpAddress(endpoint, out ipAddress))
 
-                 {
 
-                     ((ConnectManager)_connectManager).OnWanAddressResolved(ipAddress);
 
-                 }
 
-             }
 
-             catch (IOException)
 
-             {
 
-                 // File isn't there. no biggie
 
-             }
 
-             catch (Exception ex)
 
-             {
 
-                 _logger.ErrorException("Error loading data", ex);
 
-             }
 
-         }
 
-         public void Dispose()
 
-         {
 
-             if (_timer != null)
 
-             {
 
-                 _timer.Dispose();
 
-                 _timer = null;
 
-             }
 
-         }
 
-     }
 
- }
 
 
  |