1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2024-12-16 11:37:58 +02:00
Sonarr/NzbDrone.Host/Owin/OwinHostController.cs

121 lines
3.9 KiB
C#
Raw Normal View History

2013-02-19 04:13:42 +03:00
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Reflection;
using Microsoft.Owin.Hosting;
2013-02-19 04:13:42 +03:00
using NLog;
2013-08-31 01:55:01 +03:00
using NzbDrone.Common.EnvironmentInfo;
using NzbDrone.Common.Security;
using NzbDrone.Core.Configuration;
2013-08-31 01:55:01 +03:00
using NzbDrone.Host.AccessControl;
using NzbDrone.Host.Owin.MiddleWare;
using Owin;
2013-02-19 04:13:42 +03:00
namespace NzbDrone.Host.Owin
2013-02-19 04:13:42 +03:00
{
public class OwinHostController : IHostController
2013-02-19 04:13:42 +03:00
{
2013-05-11 02:53:50 +03:00
private readonly IConfigFileProvider _configFileProvider;
private readonly IEnumerable<IOwinMiddleWare> _owinMiddleWares;
2013-08-31 01:55:01 +03:00
private readonly IRuntimeInfo _runtimeInfo;
private readonly IUrlAclAdapter _urlAclAdapter;
private readonly IFirewallAdapter _firewallAdapter;
2013-09-22 22:57:03 +03:00
private readonly ISslAdapter _sslAdapter;
2013-02-19 04:13:42 +03:00
private readonly Logger _logger;
private IDisposable _host;
2013-02-19 04:13:42 +03:00
2013-09-22 22:57:03 +03:00
public OwinHostController(IConfigFileProvider configFileProvider,
IEnumerable<IOwinMiddleWare> owinMiddleWares,
IRuntimeInfo runtimeInfo,
IUrlAclAdapter urlAclAdapter,
IFirewallAdapter firewallAdapter,
ISslAdapter sslAdapter,
Logger logger)
2013-02-19 04:13:42 +03:00
{
_configFileProvider = configFileProvider;
_owinMiddleWares = owinMiddleWares;
2013-08-31 01:55:01 +03:00
_runtimeInfo = runtimeInfo;
_urlAclAdapter = urlAclAdapter;
_firewallAdapter = firewallAdapter;
2013-09-22 22:57:03 +03:00
_sslAdapter = sslAdapter;
2013-02-19 04:13:42 +03:00
_logger = logger;
}
public void StartServer()
{
IgnoreCertErrorPolicy.Register();
2013-09-21 05:50:57 +03:00
if (OsInfo.IsWindows)
{
if (_runtimeInfo.IsAdmin)
{
_firewallAdapter.MakeAccessible();
2013-09-22 22:57:03 +03:00
_sslAdapter.Register();
2013-09-21 05:50:57 +03:00
}
_urlAclAdapter.ConfigureUrl();
}
2013-09-22 22:57:03 +03:00
var options = new StartOptions(_urlAclAdapter.Url)
2013-05-06 00:24:33 +03:00
{
2013-07-06 22:10:11 +03:00
ServerFactory = "Microsoft.Owin.Host.HttpListener"
2013-05-06 00:24:33 +03:00
};
2013-09-22 22:57:03 +03:00
if (_configFileProvider.EnableSsl)
{
_logger.Trace("SSL enabled, listening on: {0}", _urlAclAdapter.HttpsUrl);
options.Urls.Add(_urlAclAdapter.HttpsUrl);
}
_logger.Info("starting server on {0}", _urlAclAdapter.Url);
2013-05-21 06:28:14 +03:00
try
{
_host = WebApp.Start(OwinServiceProviderFactory.Create(), options, BuildApp);
}
catch (TargetInvocationException ex)
{
if (ex.InnerException == null)
{
2013-09-12 00:38:35 +03:00
throw;
}
2013-09-12 00:38:35 +03:00
if (ex.InnerException is HttpListenerException)
{
2013-09-12 00:38:35 +03:00
throw new PortInUseException("Port {0} is already in use, please ensure NzbDrone is not already running.",
ex,
_configFileProvider.Port);
}
2013-09-12 00:38:35 +03:00
throw ex.InnerException;
}
}
private void BuildApp(IAppBuilder appBuilder)
{
2013-07-06 22:10:11 +03:00
appBuilder.Properties["host.AppName"] = "NzbDrone";
2013-05-06 00:24:33 +03:00
foreach (var middleWare in _owinMiddleWares.OrderBy(c => c.Order))
{
2013-05-06 00:24:33 +03:00
_logger.Debug("Attaching {0} to host", middleWare.GetType().Name);
middleWare.Attach(appBuilder);
}
}
2013-02-19 04:13:42 +03:00
public string AppUrl
{
2013-03-01 03:50:50 +03:00
get { return string.Format("http://localhost:{0}", _configFileProvider.Port); }
2013-02-19 04:13:42 +03:00
}
public void StopServer()
{
if (_host == null) return;
_logger.Info("Attempting to stop Nancy host");
_host.Dispose();
2013-02-19 04:13:42 +03:00
_host = null;
_logger.Info("Host has stopped");
}
}
}