Changed health check to send user to appropriate scenario on Wiki. Also added support to Nzbget to get the Category config.
This commit is contained in:
parent
17482cb6c1
commit
b72c9b338c
|
@ -1,6 +1,7 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using System.Collections.Generic;
|
||||||
using NLog;
|
using NLog;
|
||||||
using NzbDrone.Common;
|
using NzbDrone.Common;
|
||||||
using NzbDrone.Common.Http;
|
using NzbDrone.Common.Http;
|
||||||
|
@ -213,9 +214,55 @@ namespace NzbDrone.Core.Download.Clients.Nzbget
|
||||||
_proxy.RetryDownload(id, Settings);
|
_proxy.RetryDownload(id, Settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void Test()
|
public override DownloadClientStatus GetStatus()
|
||||||
{
|
{
|
||||||
_proxy.GetVersion(Settings);
|
var config = _proxy.GetConfig(Settings);
|
||||||
|
|
||||||
|
var category = GetCategories(config).FirstOrDefault(v => v.Name == Settings.TvCategory);
|
||||||
|
|
||||||
|
var status = new DownloadClientStatus
|
||||||
|
{
|
||||||
|
IsLocalhost = Settings.Host == "127.0.0.1" || Settings.Host == "localhost"
|
||||||
|
};
|
||||||
|
|
||||||
|
if (category != null)
|
||||||
|
{
|
||||||
|
status.OutputRootFolders = new List<string> { category.DestDir };
|
||||||
|
}
|
||||||
|
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected IEnumerable<NzbgetCategory> GetCategories(Dictionary<String, String> config)
|
||||||
|
{
|
||||||
|
for (int i = 1; i < 100; i++)
|
||||||
|
{
|
||||||
|
var name = config.GetValueOrDefault("Category" + i + ".Name");
|
||||||
|
|
||||||
|
if (name == null) yield break;
|
||||||
|
|
||||||
|
var destDir = config.GetValueOrDefault("Category" + i + ".DestDir");
|
||||||
|
|
||||||
|
if (destDir.IsNullOrWhiteSpace())
|
||||||
|
{
|
||||||
|
var mainDir = config.GetValueOrDefault("MainDir");
|
||||||
|
destDir = config.GetValueOrDefault("DestDir", String.Empty).Replace("${MainDir}", mainDir);
|
||||||
|
|
||||||
|
if (config.GetValueOrDefault("AppendCategoryDir", "yes") == "yes")
|
||||||
|
{
|
||||||
|
destDir = Path.Combine(destDir, name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
yield return new NzbgetCategory
|
||||||
|
{
|
||||||
|
Name = name,
|
||||||
|
DestDir = destDir,
|
||||||
|
Unpack = config.GetValueOrDefault("Category" + i + ".Unpack") == "yes",
|
||||||
|
DefScript = config.GetValueOrDefault("Category" + i + ".DefScript"),
|
||||||
|
Aliases = config.GetValueOrDefault("Category" + i + ".Aliases"),
|
||||||
|
};
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private String GetVersion(string host = null, int port = 0, string username = null, string password = null)
|
private String GetVersion(string host = null, int port = 0, string username = null, string password = null)
|
||||||
|
@ -223,6 +270,11 @@ namespace NzbDrone.Core.Download.Clients.Nzbget
|
||||||
return _proxy.GetVersion(Settings);
|
return _proxy.GetVersion(Settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override void Test()
|
||||||
|
{
|
||||||
|
_proxy.GetVersion(Settings);
|
||||||
|
}
|
||||||
|
|
||||||
public void Execute(TestNzbgetCommand message)
|
public void Execute(TestNzbgetCommand message)
|
||||||
{
|
{
|
||||||
var settings = new NzbgetSettings();
|
var settings = new NzbgetSettings();
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
|
||||||
|
namespace NzbDrone.Core.Download.Clients.Nzbget
|
||||||
|
{
|
||||||
|
public class NzbgetCategory
|
||||||
|
{
|
||||||
|
public String Name { get; set; }
|
||||||
|
public String DestDir { get; set; }
|
||||||
|
public Boolean Unpack { get; set; }
|
||||||
|
public String DefScript { get; set; }
|
||||||
|
public String Aliases { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,13 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
|
||||||
|
namespace NzbDrone.Core.Download.Clients.Nzbget
|
||||||
|
{
|
||||||
|
public class NzbgetConfigItem
|
||||||
|
{
|
||||||
|
public String Name { get; set; }
|
||||||
|
public String Value { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -18,6 +18,7 @@ namespace NzbDrone.Core.Download.Clients.Nzbget
|
||||||
List<NzbgetPostQueueItem> GetPostQueue(NzbgetSettings settings);
|
List<NzbgetPostQueueItem> GetPostQueue(NzbgetSettings settings);
|
||||||
List<NzbgetHistoryItem> GetHistory(NzbgetSettings settings);
|
List<NzbgetHistoryItem> GetHistory(NzbgetSettings settings);
|
||||||
String GetVersion(NzbgetSettings settings);
|
String GetVersion(NzbgetSettings settings);
|
||||||
|
Dictionary<String, String> GetConfig(NzbgetSettings settings);
|
||||||
void RemoveFromHistory(string id, NzbgetSettings settings);
|
void RemoveFromHistory(string id, NzbgetSettings settings);
|
||||||
void RetryDownload(string id, NzbgetSettings settings);
|
void RetryDownload(string id, NzbgetSettings settings);
|
||||||
}
|
}
|
||||||
|
@ -98,6 +99,14 @@ namespace NzbDrone.Core.Download.Clients.Nzbget
|
||||||
return Json.Deserialize<NzbgetResponse<String>>(ProcessRequest(request, settings)).Version;
|
return Json.Deserialize<NzbgetResponse<String>>(ProcessRequest(request, settings)).Version;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Dictionary<String, String> GetConfig(NzbgetSettings settings)
|
||||||
|
{
|
||||||
|
var request = BuildRequest(new JsonRequest("config"));
|
||||||
|
|
||||||
|
return Json.Deserialize<NzbgetResponse<List<NzbgetConfigItem>>>(ProcessRequest(request, settings)).Result.ToDictionary(v => v.Name, v => v.Value);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public void RemoveFromHistory(string id, NzbgetSettings settings)
|
public void RemoveFromHistory(string id, NzbgetSettings settings)
|
||||||
{
|
{
|
||||||
var history = GetHistory(settings);
|
var history = GetHistory(settings);
|
||||||
|
|
|
@ -90,6 +90,16 @@ namespace NzbDrone.Core.Download.Clients.Pneumatic
|
||||||
throw new NotSupportedException();
|
throw new NotSupportedException();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override DownloadClientStatus GetStatus()
|
||||||
|
{
|
||||||
|
var status = new DownloadClientStatus
|
||||||
|
{
|
||||||
|
IsLocalhost = true
|
||||||
|
};
|
||||||
|
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
public override void Test()
|
public override void Test()
|
||||||
{
|
{
|
||||||
PerformTest(Settings.NzbFolder);
|
PerformTest(Settings.NzbFolder);
|
||||||
|
|
|
@ -208,6 +208,16 @@ namespace NzbDrone.Core.Download.Clients.Sabnzbd
|
||||||
_proxy.RetryDownload(id, Settings);
|
_proxy.RetryDownload(id, Settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override DownloadClientStatus GetStatus()
|
||||||
|
{
|
||||||
|
var status = new DownloadClientStatus
|
||||||
|
{
|
||||||
|
IsLocalhost = Settings.Host == "127.0.0.1" || Settings.Host == "localhost"
|
||||||
|
};
|
||||||
|
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
public override void Test()
|
public override void Test()
|
||||||
{
|
{
|
||||||
_proxy.GetCategories(Settings);
|
_proxy.GetCategories(Settings);
|
||||||
|
|
|
@ -142,6 +142,15 @@ namespace NzbDrone.Core.Download.Clients.UsenetBlackhole
|
||||||
PerformTest(Settings.WatchFolder);
|
PerformTest(Settings.WatchFolder);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override DownloadClientStatus GetStatus()
|
||||||
|
{
|
||||||
|
return new DownloadClientStatus
|
||||||
|
{
|
||||||
|
IsLocalhost = true,
|
||||||
|
OutputRootFolders = new List<string> { Settings.WatchFolder }
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
private void PerformTest(string folder)
|
private void PerformTest(string folder)
|
||||||
{
|
{
|
||||||
var testPath = Path.Combine(folder, "drone_test.txt");
|
var testPath = Path.Combine(folder, "drone_test.txt");
|
||||||
|
|
|
@ -67,6 +67,7 @@ namespace NzbDrone.Core.Download
|
||||||
public abstract void RemoveItem(string id);
|
public abstract void RemoveItem(string id);
|
||||||
public abstract void RetryDownload(string id);
|
public abstract void RetryDownload(string id);
|
||||||
public abstract void Test();
|
public abstract void Test();
|
||||||
|
public abstract DownloadClientStatus GetStatus();
|
||||||
|
|
||||||
protected RemoteEpisode GetRemoteEpisode(String title)
|
protected RemoteEpisode GetRemoteEpisode(String title)
|
||||||
{
|
{
|
||||||
|
|
|
@ -0,0 +1,13 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
|
||||||
|
namespace NzbDrone.Core.Download
|
||||||
|
{
|
||||||
|
public class DownloadClientStatus
|
||||||
|
{
|
||||||
|
public Boolean IsLocalhost { get; set; }
|
||||||
|
public List<String> OutputRootFolders { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -14,5 +14,7 @@ namespace NzbDrone.Core.Download
|
||||||
void RemoveItem(string id);
|
void RemoveItem(string id);
|
||||||
void RetryDownload(string id);
|
void RetryDownload(string id);
|
||||||
void Test();
|
void Test();
|
||||||
|
|
||||||
|
DownloadClientStatus GetStatus();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,37 +5,74 @@ using NzbDrone.Common;
|
||||||
using NzbDrone.Common.Disk;
|
using NzbDrone.Common.Disk;
|
||||||
using NzbDrone.Core.Configuration;
|
using NzbDrone.Core.Configuration;
|
||||||
using NzbDrone.Core.Download;
|
using NzbDrone.Core.Download;
|
||||||
|
using NzbDrone.Core.Download.Clients.Sabnzbd;
|
||||||
|
using NzbDrone.Core.Download.Clients.Nzbget;
|
||||||
|
|
||||||
namespace NzbDrone.Core.HealthCheck.Checks
|
namespace NzbDrone.Core.HealthCheck.Checks
|
||||||
{
|
{
|
||||||
public class ImportMechanismCheck : HealthCheckBase
|
public class ImportMechanismCheck : HealthCheckBase
|
||||||
{
|
{
|
||||||
private readonly IConfigService _configService;
|
private readonly IConfigService _configService;
|
||||||
|
private readonly IProvideDownloadClient _provideDownloadClient;
|
||||||
private readonly IDownloadTrackingService _downloadTrackingService;
|
private readonly IDownloadTrackingService _downloadTrackingService;
|
||||||
|
|
||||||
public ImportMechanismCheck(IConfigService configService, IDownloadTrackingService downloadTrackingService)
|
public ImportMechanismCheck(IConfigService configService, IProvideDownloadClient provideDownloadClient, IDownloadTrackingService downloadTrackingService)
|
||||||
{
|
{
|
||||||
_configService = configService;
|
_configService = configService;
|
||||||
|
_provideDownloadClient = provideDownloadClient;
|
||||||
_downloadTrackingService = downloadTrackingService;
|
_downloadTrackingService = downloadTrackingService;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override HealthCheck Check()
|
public override HealthCheck Check()
|
||||||
{
|
{
|
||||||
|
var droneFactoryFolder = _configService.DownloadedEpisodesFolder;
|
||||||
|
var downloadClients = _provideDownloadClient.GetDownloadClients().Select(v => new { downloadClient = v, status = v.GetStatus() }).ToList();
|
||||||
|
|
||||||
|
var downloadClientIsLocalHost = downloadClients.All(v => v.status.IsLocalhost);
|
||||||
|
var downloadClientOutputInDroneFactory = !droneFactoryFolder.IsNullOrWhiteSpace()
|
||||||
|
&& downloadClients.Any(v => v.status.OutputRootFolders != null && v.status.OutputRootFolders.Contains(droneFactoryFolder, PathEqualityComparer.Instance));
|
||||||
|
|
||||||
if (!_configService.IsDefined("EnableCompletedDownloadHandling"))
|
if (!_configService.IsDefined("EnableCompletedDownloadHandling"))
|
||||||
{
|
{
|
||||||
return new HealthCheck(GetType(), HealthCheckResult.Warning, "Completed Download Handling is disabled");
|
// Migration helper logic
|
||||||
}
|
if (!downloadClientIsLocalHost)
|
||||||
|
{
|
||||||
|
return new HealthCheck(GetType(), HealthCheckResult.Warning, "Enable Completed Download Handling if possible (Multi-Computer unsupported)", "Migrating-to-Completed-Download-Handling#Unsupported-download-client-on-different-computer");
|
||||||
|
}
|
||||||
|
|
||||||
var droneFactoryFolder = _configService.DownloadedEpisodesFolder;
|
if (downloadClients.All(v => v.downloadClient is Sabnzbd))
|
||||||
|
{
|
||||||
|
// With Sabnzbd we cannot check the category settings.
|
||||||
|
|
||||||
|
return new HealthCheck(GetType(), HealthCheckResult.Warning, "Enable Completed Download Handling if possible (Sabnzbd)", "Migrating-to-Completed-Download-Handling#sabnzbd-enable-completed-download-handling");
|
||||||
|
}
|
||||||
|
else if (downloadClients.All(v => v.downloadClient is Nzbget))
|
||||||
|
{
|
||||||
|
// With Nzbget we can check if the category should be changed.
|
||||||
|
if (downloadClientOutputInDroneFactory)
|
||||||
|
{
|
||||||
|
return new HealthCheck(GetType(), HealthCheckResult.Warning, "Enable Completed Download Handling if possible (Nzbget - Conflicting Category)", "Migrating-to-Completed-Download-Handling#nzbget-conflicting-download-client-category");
|
||||||
|
}
|
||||||
|
|
||||||
|
return new HealthCheck(GetType(), HealthCheckResult.Warning, "Enable Completed Download Handling if possible (Nzbget)", "Migrating-to-Completed-Download-Handling#nzbget-enable-completed-download-handling");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return new HealthCheck(GetType(), HealthCheckResult.Warning, "Enable Completed Download Handling if possible", "Migrating-to-Completed-Download-Handling");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!_configService.EnableCompletedDownloadHandling && droneFactoryFolder.IsNullOrWhiteSpace())
|
if (!_configService.EnableCompletedDownloadHandling && droneFactoryFolder.IsNullOrWhiteSpace())
|
||||||
{
|
{
|
||||||
return new HealthCheck(GetType(), HealthCheckResult.Warning, "Enable Completed Download Handling or configure Drone factory");
|
return new HealthCheck(GetType(), HealthCheckResult.Warning, "Enable Completed Download Handling or configure Drone factory");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_configService.EnableCompletedDownloadHandling && !droneFactoryFolder.IsNullOrWhiteSpace() && _downloadTrackingService.GetCompletedDownloads().Any(v => droneFactoryFolder.PathEquals(v.DownloadItem.OutputPath) || droneFactoryFolder.IsParentPath(v.DownloadItem.OutputPath)))
|
if (_configService.EnableCompletedDownloadHandling && !droneFactoryFolder.IsNullOrWhiteSpace())
|
||||||
{
|
{
|
||||||
return new HealthCheck(GetType(), HealthCheckResult.Warning, "Download Client has history items in Drone Factory conflicting with Completed Download Handling");
|
if (_downloadTrackingService.GetCompletedDownloads().Any(v => droneFactoryFolder.PathEquals(v.DownloadItem.OutputPath) || droneFactoryFolder.IsParentPath(v.DownloadItem.OutputPath)))
|
||||||
|
{
|
||||||
|
return new HealthCheck(GetType(), HealthCheckResult.Warning, "Completed Download Handling conflict with Drone Factory (Conflicting History Item)", "Migrating-to-Completed-Download-Handling#conflicting-download-client-category");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new HealthCheck(GetType());
|
return new HealthCheck(GetType());
|
||||||
|
|
|
@ -240,6 +240,8 @@
|
||||||
<Compile Include="DecisionEngine\Specifications\RssSync\HistorySpecification.cs" />
|
<Compile Include="DecisionEngine\Specifications\RssSync\HistorySpecification.cs" />
|
||||||
<Compile Include="DiskSpace\DiskSpace.cs" />
|
<Compile Include="DiskSpace\DiskSpace.cs" />
|
||||||
<Compile Include="DiskSpace\DiskSpaceService.cs" />
|
<Compile Include="DiskSpace\DiskSpaceService.cs" />
|
||||||
|
<Compile Include="Download\Clients\Nzbget\NzbgetCategory.cs" />
|
||||||
|
<Compile Include="Download\Clients\Nzbget\NzbgetConfigItem.cs" />
|
||||||
<Compile Include="Download\Clients\Nzbget\NzbgetGlobalStatus.cs" />
|
<Compile Include="Download\Clients\Nzbget\NzbgetGlobalStatus.cs" />
|
||||||
<Compile Include="Download\Clients\Nzbget\NzbgetPostQueueItem.cs" />
|
<Compile Include="Download\Clients\Nzbget\NzbgetPostQueueItem.cs" />
|
||||||
<Compile Include="Download\Clients\Sabnzbd\SabnzbdDownloadStatus.cs" />
|
<Compile Include="Download\Clients\Sabnzbd\SabnzbdDownloadStatus.cs" />
|
||||||
|
@ -271,6 +273,7 @@
|
||||||
<Compile Include="Download\Clients\Sabnzbd\SabnzbdProxy.cs" />
|
<Compile Include="Download\Clients\Sabnzbd\SabnzbdProxy.cs" />
|
||||||
<Compile Include="Download\CheckForFinishedDownloadCommand.cs" />
|
<Compile Include="Download\CheckForFinishedDownloadCommand.cs" />
|
||||||
<Compile Include="Download\DownloadClientItem.cs" />
|
<Compile Include="Download\DownloadClientItem.cs" />
|
||||||
|
<Compile Include="Download\DownloadClientStatus.cs" />
|
||||||
<Compile Include="Download\FailedDownloadService.cs" />
|
<Compile Include="Download\FailedDownloadService.cs" />
|
||||||
<Compile Include="Download\DownloadItemStatus.cs" />
|
<Compile Include="Download\DownloadItemStatus.cs" />
|
||||||
<Compile Include="Download\TrackedDownload.cs" />
|
<Compile Include="Download\TrackedDownload.cs" />
|
||||||
|
|
Loading…
Reference in New Issue