Lidarr/src/NzbDrone.Core/HealthCheck/Checks/DownloadClientCheck.cs

47 lines
1.4 KiB
C#
Raw Normal View History

2014-02-26 05:40:47 +00:00
using System;
using System.Linq;
using NLog;
2014-02-26 05:40:47 +00:00
using NzbDrone.Core.Download;
namespace NzbDrone.Core.HealthCheck.Checks
{
public class DownloadClientCheck : HealthCheckBase
2014-02-26 05:40:47 +00:00
{
private readonly IProvideDownloadClient _downloadClientProvider;
private readonly Logger _logger;
2014-02-26 05:40:47 +00:00
public DownloadClientCheck(IProvideDownloadClient downloadClientProvider, Logger logger)
2014-02-26 05:40:47 +00:00
{
_downloadClientProvider = downloadClientProvider;
_logger = logger;
2014-02-26 05:40:47 +00:00
}
public override HealthCheck Check()
2014-02-26 05:40:47 +00:00
{
var downloadClients = _downloadClientProvider.GetDownloadClients().ToList();
2014-02-26 05:40:47 +00:00
if (!downloadClients.Any())
2014-02-26 05:40:47 +00:00
{
return new HealthCheck(GetType(), HealthCheckResult.Warning, "No download client is available");
2014-02-26 05:40:47 +00:00
}
foreach (var downloadClient in downloadClients)
2014-02-26 05:40:47 +00:00
{
try
{
downloadClient.GetItems();
}
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);
return new HealthCheck(GetType(), HealthCheckResult.Error, message + " " + ex.Message);
}
2014-02-26 05:40:47 +00:00
}
return new HealthCheck(GetType());
2014-02-26 05:40:47 +00:00
}
}
}