2013-02-18 17:13:42 -08:00
|
|
|
using System;
|
2013-05-04 13:29:24 -07:00
|
|
|
using System.Collections.Generic;
|
2013-08-06 22:32:22 -07:00
|
|
|
using System.Linq;
|
2013-05-04 13:29:24 -07:00
|
|
|
using Microsoft.Owin.Hosting;
|
2013-02-18 17:13:42 -08:00
|
|
|
using NLog;
|
2013-08-30 15:55:01 -07:00
|
|
|
using NzbDrone.Common.EnvironmentInfo;
|
2013-07-07 10:27:11 -07:00
|
|
|
using NzbDrone.Common.Security;
|
2013-05-22 22:12:01 -07:00
|
|
|
using NzbDrone.Core.Configuration;
|
2013-08-30 15:55:01 -07:00
|
|
|
using NzbDrone.Host.AccessControl;
|
2013-08-06 22:32:22 -07:00
|
|
|
using NzbDrone.Host.Owin.MiddleWare;
|
2013-05-04 13:29:24 -07:00
|
|
|
using Owin;
|
2013-02-18 17:13:42 -08:00
|
|
|
|
2013-08-06 22:32:22 -07:00
|
|
|
namespace NzbDrone.Host.Owin
|
2013-02-18 17:13:42 -08:00
|
|
|
{
|
2013-05-04 13:29:24 -07:00
|
|
|
public class OwinHostController : IHostController
|
2013-02-18 17:13:42 -08:00
|
|
|
{
|
2013-05-10 16:53:50 -07:00
|
|
|
private readonly IConfigFileProvider _configFileProvider;
|
2013-05-04 14:09:25 -07:00
|
|
|
private readonly IEnumerable<IOwinMiddleWare> _owinMiddleWares;
|
2013-08-30 15:55:01 -07:00
|
|
|
private readonly IRuntimeInfo _runtimeInfo;
|
|
|
|
private readonly IUrlAclAdapter _urlAclAdapter;
|
|
|
|
private readonly IFirewallAdapter _firewallAdapter;
|
2013-02-18 17:13:42 -08:00
|
|
|
private readonly Logger _logger;
|
2013-05-04 13:29:24 -07:00
|
|
|
private IDisposable _host;
|
2013-02-18 17:13:42 -08:00
|
|
|
|
2013-08-30 15:55:01 -07:00
|
|
|
public OwinHostController(IConfigFileProvider configFileProvider, IEnumerable<IOwinMiddleWare> owinMiddleWares,
|
|
|
|
IRuntimeInfo runtimeInfo, IUrlAclAdapter urlAclAdapter, IFirewallAdapter firewallAdapter, Logger logger)
|
2013-02-18 17:13:42 -08:00
|
|
|
{
|
|
|
|
_configFileProvider = configFileProvider;
|
2013-05-04 14:09:25 -07:00
|
|
|
_owinMiddleWares = owinMiddleWares;
|
2013-08-30 15:55:01 -07:00
|
|
|
_runtimeInfo = runtimeInfo;
|
|
|
|
_urlAclAdapter = urlAclAdapter;
|
|
|
|
_firewallAdapter = firewallAdapter;
|
2013-02-18 17:13:42 -08:00
|
|
|
_logger = logger;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void StartServer()
|
|
|
|
{
|
2013-07-07 10:27:11 -07:00
|
|
|
IgnoreCertErrorPolicy.Register();
|
|
|
|
|
2013-08-30 15:55:01 -07:00
|
|
|
if (OsInfo.IsWindows && _runtimeInfo.IsAdmin)
|
|
|
|
{
|
|
|
|
_urlAclAdapter.RefreshRegistration();
|
|
|
|
_firewallAdapter.MakeAccessible();
|
|
|
|
}
|
2013-07-06 12:10:11 -07:00
|
|
|
|
2013-08-30 15:55:01 -07:00
|
|
|
var options = new StartOptions(_urlAclAdapter.UrlAcl)
|
2013-05-05 14:24:33 -07:00
|
|
|
{
|
2013-07-06 12:10:11 -07:00
|
|
|
ServerFactory = "Microsoft.Owin.Host.HttpListener"
|
2013-05-05 14:24:33 -07:00
|
|
|
};
|
|
|
|
|
2013-08-30 15:55:01 -07:00
|
|
|
_logger.Info("starting server on {0}", _urlAclAdapter.UrlAcl);
|
2013-05-20 20:28:14 -07:00
|
|
|
|
2013-08-28 15:25:12 -07:00
|
|
|
_host = WebApp.Start(OwinServiceProviderFactory.Create(), options, BuildApp);
|
2013-05-04 14:09:25 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
private void BuildApp(IAppBuilder appBuilder)
|
|
|
|
{
|
2013-07-06 12:10:11 -07:00
|
|
|
appBuilder.Properties["host.AppName"] = "NzbDrone";
|
|
|
|
|
2013-05-05 14:24:33 -07:00
|
|
|
foreach (var middleWare in _owinMiddleWares.OrderBy(c => c.Order))
|
2013-05-04 14:09:25 -07:00
|
|
|
{
|
2013-05-05 14:24:33 -07:00
|
|
|
_logger.Debug("Attaching {0} to host", middleWare.GetType().Name);
|
2013-05-04 14:09:25 -07:00
|
|
|
middleWare.Attach(appBuilder);
|
|
|
|
}
|
2013-05-04 13:29:24 -07:00
|
|
|
}
|
2013-03-25 21:03:16 -07:00
|
|
|
|
2013-02-18 17:13:42 -08:00
|
|
|
public string AppUrl
|
|
|
|
{
|
2013-02-28 16:50:50 -08:00
|
|
|
get { return string.Format("http://localhost:{0}", _configFileProvider.Port); }
|
2013-02-18 17:13:42 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
public void StopServer()
|
|
|
|
{
|
|
|
|
if (_host == null) return;
|
|
|
|
|
|
|
|
_logger.Info("Attempting to stop Nancy host");
|
2013-05-04 13:29:24 -07:00
|
|
|
_host.Dispose();
|
2013-02-18 17:13:42 -08:00
|
|
|
_host = null;
|
|
|
|
_logger.Info("Host has stopped");
|
|
|
|
}
|
2013-05-04 13:29:24 -07:00
|
|
|
|
2013-02-18 17:13:42 -08:00
|
|
|
}
|
|
|
|
}
|