Radarr/src/NzbDrone.Host/Owin/OwinHostController.cs

51 lines
1.5 KiB
C#

using System;
using NLog;
using NzbDrone.Common.EnvironmentInfo;
using Radarr.Host.AccessControl;
namespace Radarr.Host.Owin
{
public class OwinHostController : IHostController
{
private readonly IOwinAppFactory _owinAppFactory;
private readonly IRemoteAccessAdapter _removeAccessAdapter;
private readonly IUrlAclAdapter _urlAclAdapter;
private readonly Logger _logger;
private IDisposable _owinApp;
public OwinHostController(
IOwinAppFactory owinAppFactory,
IRemoteAccessAdapter removeAccessAdapter,
IUrlAclAdapter urlAclAdapter,
Logger logger)
{
_owinAppFactory = owinAppFactory;
_removeAccessAdapter = removeAccessAdapter;
_urlAclAdapter = urlAclAdapter;
_logger = logger;
}
public void StartServer()
{
_removeAccessAdapter.MakeAccessible(true);
_logger.Info("Listening on the following URLs:");
foreach (var url in _urlAclAdapter.Urls)
{
_logger.Info(" {0}", url);
}
_owinApp = _owinAppFactory.CreateApp(_urlAclAdapter.Urls);
}
public void StopServer()
{
if (_owinApp == null) return;
_logger.Info("Attempting to stop OWIN host");
_owinApp.Dispose();
_owinApp = null;
_logger.Info("Host has stopped");
}
}
}