mirror of
https://github.com/Sonarr/Sonarr.git
synced 2024-10-30 07:22:35 +01:00
Don't get registered URLs until they need to be configured
This commit is contained in:
parent
17ff52ada1
commit
56825da6b6
@ -32,7 +32,7 @@ namespace NzbDrone.Host.AccessControl
|
|||||||
}
|
}
|
||||||
|
|
||||||
private List<UrlAcl> InternalUrls { get; }
|
private List<UrlAcl> InternalUrls { get; }
|
||||||
private List<UrlAcl> RegisteredUrls { get; }
|
private List<UrlAcl> RegisteredUrls { get; set; }
|
||||||
|
|
||||||
private static readonly Regex UrlAclRegex = new Regex(@"(?<scheme>https?)\:\/\/(?<address>.+?)\:(?<port>\d+)/(?<urlbase>.+)?", RegexOptions.Compiled | RegexOptions.IgnoreCase);
|
private static readonly Regex UrlAclRegex = new Regex(@"(?<scheme>https?)\:\/\/(?<address>.+?)\:(?<port>\d+)/(?<urlbase>.+)?", RegexOptions.Compiled | RegexOptions.IgnoreCase);
|
||||||
|
|
||||||
@ -49,11 +49,16 @@ namespace NzbDrone.Host.AccessControl
|
|||||||
_logger = logger;
|
_logger = logger;
|
||||||
|
|
||||||
InternalUrls = new List<UrlAcl>();
|
InternalUrls = new List<UrlAcl>();
|
||||||
RegisteredUrls = GetRegisteredUrls();
|
RegisteredUrls = new List<UrlAcl>();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ConfigureUrls()
|
public void ConfigureUrls()
|
||||||
{
|
{
|
||||||
|
if (RegisteredUrls.Empty())
|
||||||
|
{
|
||||||
|
GetRegisteredUrls();
|
||||||
|
}
|
||||||
|
|
||||||
var localHostHttpUrls = BuildUrlAcls("http", "localhost", _configFileProvider.Port);
|
var localHostHttpUrls = BuildUrlAcls("http", "localhost", _configFileProvider.Port);
|
||||||
var interfaceHttpUrls = BuildUrlAcls("http", _configFileProvider.BindAddress, _configFileProvider.Port);
|
var interfaceHttpUrls = BuildUrlAcls("http", _configFileProvider.BindAddress, _configFileProvider.Port);
|
||||||
|
|
||||||
@ -128,19 +133,24 @@ namespace NzbDrone.Host.AccessControl
|
|||||||
c.UrlBase == urlAcl.UrlBase);
|
c.UrlBase == urlAcl.UrlBase);
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<UrlAcl> GetRegisteredUrls()
|
private void GetRegisteredUrls()
|
||||||
{
|
{
|
||||||
if (OsInfo.IsNotWindows)
|
if (OsInfo.IsNotWindows)
|
||||||
{
|
{
|
||||||
return new List<UrlAcl>();
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (RegisteredUrls.Any())
|
||||||
|
{
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var arguments = string.Format("http show urlacl");
|
var arguments = string.Format("http show urlacl");
|
||||||
var output = _netshProvider.Run(arguments);
|
var output = _netshProvider.Run(arguments);
|
||||||
|
|
||||||
if (output == null || !output.Standard.Any()) return new List<UrlAcl>();
|
if (output == null || !output.Standard.Any()) return;
|
||||||
|
|
||||||
return output.Standard.Select(line =>
|
RegisteredUrls = output.Standard.Select(line =>
|
||||||
{
|
{
|
||||||
var match = UrlAclRegex.Match(line.Content);
|
var match = UrlAclRegex.Match(line.Content);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user