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:
Taloth Saldono 2014-06-06 07:55:38 +02:00
parent 17482cb6c1
commit b72c9b338c
12 changed files with 184 additions and 9 deletions

View File

@ -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();

View File

@ -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; }
}
}

View File

@ -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; }
}
}

View File

@ -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);

View File

@ -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);

View File

@ -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);

View File

@ -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");

View File

@ -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)
{ {

View File

@ -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; }
}
}

View File

@ -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();
} }
} }

View File

@ -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());

View File

@ -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" />