2014-02-26 05:40:47 +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;
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.HealthCheck.Checks
|
|
|
|
|
{
|
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)
|
|
|
|
|
{
|
|
|
|
|
var message = String.Format("Unable to communicate with {0}.", downloadClient.Definition.Name);
|
|
|
|
|
|
2016-02-11 21:13:42 +00:00
|
|
|
|
_logger.Error(ex, message);
|
2015-10-28 05:19:24 +00:00
|
|
|
|
return new HealthCheck(GetType(), HealthCheckResult.Error, message + " " + ex.Message);
|
|
|
|
|
}
|
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
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|