2017-10-27 03:21:06 +00:00
|
|
|
using System;
|
2014-04-19 15:09:22 +00:00
|
|
|
using System.Linq;
|
2014-12-15 20:18:09 +00:00
|
|
|
using NLog;
|
2014-02-26 05:40:47 +00:00
|
|
|
using NzbDrone.Core.Download;
|
2017-10-27 03:21:06 +00:00
|
|
|
using NzbDrone.Core.ThingiProvider.Events;
|
2014-02-26 05:40:47 +00:00
|
|
|
|
|
|
|
namespace NzbDrone.Core.HealthCheck.Checks
|
|
|
|
{
|
2019-01-27 01:58:46 +00:00
|
|
|
[CheckOn(typeof(ProviderAddedEvent<IDownloadClient>))]
|
2017-10-27 03:21:06 +00:00
|
|
|
[CheckOn(typeof(ProviderUpdatedEvent<IDownloadClient>))]
|
|
|
|
[CheckOn(typeof(ProviderDeletedEvent<IDownloadClient>))]
|
2020-09-07 04:41:25 +00:00
|
|
|
[CheckOn(typeof(ProviderStatusChangedEvent<IDownloadClient>))]
|
2014-04-10 00:15:13 +00:00
|
|
|
public class DownloadClientCheck : HealthCheckBase
|
2014-02-26 05:40:47 +00:00
|
|
|
{
|
|
|
|
private readonly IProvideDownloadClient _downloadClientProvider;
|
2014-12-15 20:18:09 +00:00
|
|
|
private readonly Logger _logger;
|
2014-02-26 05:40:47 +00:00
|
|
|
|
2014-12-15 20:18:09 +00:00
|
|
|
public DownloadClientCheck(IProvideDownloadClient downloadClientProvider, Logger logger)
|
2014-02-26 05:40:47 +00:00
|
|
|
{
|
|
|
|
_downloadClientProvider = downloadClientProvider;
|
2014-12-15 20:18:09 +00:00
|
|
|
_logger = logger;
|
2014-02-26 05:40:47 +00:00
|
|
|
}
|
|
|
|
|
2014-04-10 00:15:13 +00:00
|
|
|
public override HealthCheck Check()
|
2014-02-26 05:40:47 +00:00
|
|
|
{
|
2014-10-13 18:07:05 +00:00
|
|
|
var downloadClients = _downloadClientProvider.GetDownloadClients().ToList();
|
2014-02-26 05:40:47 +00:00
|
|
|
|
2014-10-13 18:07:05 +00:00
|
|
|
if (!downloadClients.Any())
|
2014-02-26 05:40:47 +00:00
|
|
|
{
|
2014-04-10 00:15:13 +00:00
|
|
|
return new HealthCheck(GetType(), HealthCheckResult.Warning, "No download client is available");
|
2014-02-26 05:40:47 +00:00
|
|
|
}
|
|
|
|
|
2015-10-28 05:19:24 +00:00
|
|
|
foreach (var downloadClient in downloadClients)
|
2014-02-26 05:40:47 +00:00
|
|
|
{
|
2015-10-28 05:19:24 +00:00
|
|
|
try
|
2014-04-19 15:09:22 +00:00
|
|
|
{
|
|
|
|
downloadClient.GetItems();
|
|
|
|
}
|
2015-10-28 05:19:24 +00:00
|
|
|
catch (Exception ex)
|
|
|
|
{
|
2017-10-27 03:21:06 +00:00
|
|
|
_logger.Debug(ex, "Unable to communicate with {0}", downloadClient.Definition.Name);
|
2017-01-05 23:32:17 +00:00
|
|
|
|
|
|
|
var message = $"Unable to communicate with {downloadClient.Definition.Name}.";
|
2021-08-04 22:47:40 +00:00
|
|
|
return new HealthCheck(GetType(), HealthCheckResult.Error, $"{message} {ex.Message}", "#unable-to-communicate-with-download-client");
|
2015-10-28 05:19:24 +00:00
|
|
|
}
|
2014-02-26 05:40:47 +00:00
|
|
|
}
|
|
|
|
|
2014-04-10 00:15:13 +00:00
|
|
|
return new HealthCheck(GetType());
|
2014-02-26 05:40:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|