You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
92 lines
3.1 KiB
92 lines
3.1 KiB
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Net;
|
|
using NLog;
|
|
using NzbDrone.Common.Cloud;
|
|
using NzbDrone.Common.Http;
|
|
using NzbDrone.Core.Configuration;
|
|
using NzbDrone.Core.Configuration.Events;
|
|
using NzbDrone.Core.Localization;
|
|
|
|
namespace NzbDrone.Core.HealthCheck.Checks
|
|
{
|
|
[CheckOn(typeof(ConfigSavedEvent))]
|
|
public class ProxyCheck : HealthCheckBase
|
|
{
|
|
private readonly Logger _logger;
|
|
private readonly IConfigService _configService;
|
|
private readonly IHttpClient _client;
|
|
|
|
private readonly IHttpRequestBuilderFactory _cloudRequestBuilder;
|
|
|
|
public ProxyCheck(IProwlarrCloudRequestBuilder cloudRequestBuilder, IConfigService configService, IHttpClient client, Logger logger, ILocalizationService localizationService)
|
|
: base(localizationService)
|
|
{
|
|
_configService = configService;
|
|
_client = client;
|
|
_logger = logger;
|
|
|
|
_cloudRequestBuilder = cloudRequestBuilder.Services;
|
|
}
|
|
|
|
public override HealthCheck Check()
|
|
{
|
|
if (!_configService.ProxyEnabled)
|
|
{
|
|
return new HealthCheck(GetType());
|
|
}
|
|
|
|
var addresses = Dns.GetHostAddresses(_configService.ProxyHostname);
|
|
|
|
if (!addresses.Any())
|
|
{
|
|
return new HealthCheck(GetType(),
|
|
HealthCheckResult.Error,
|
|
_localizationService.GetLocalizedString("ProxyResolveIpHealthCheckMessage", new Dictionary<string, object>
|
|
{
|
|
{ "proxyHostName", _configService.ProxyHostname }
|
|
}),
|
|
"#proxy-failed-resolve-ip");
|
|
}
|
|
|
|
var request = _cloudRequestBuilder.Create()
|
|
.Resource("/ping")
|
|
.Build();
|
|
|
|
try
|
|
{
|
|
var response = _client.Execute(request);
|
|
|
|
// We only care about 400 responses, other error codes can be ignored
|
|
if (response.StatusCode == HttpStatusCode.BadRequest)
|
|
{
|
|
_logger.Error("Proxy Health Check failed: {0}", response.StatusCode);
|
|
|
|
return new HealthCheck(GetType(),
|
|
HealthCheckResult.Error,
|
|
_localizationService.GetLocalizedString("ProxyBadRequestHealthCheckMessage", new Dictionary<string, object>
|
|
{
|
|
{ "statusCode", response.StatusCode }
|
|
}),
|
|
"#proxy-failed-test");
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
_logger.Error(ex, "Proxy Health Check failed");
|
|
|
|
return new HealthCheck(GetType(),
|
|
HealthCheckResult.Error,
|
|
_localizationService.GetLocalizedString("ProxyFailedToTestHealthCheckMessage", new Dictionary<string, object>
|
|
{
|
|
{ "url", request.Url }
|
|
}),
|
|
"#proxy-failed-test");
|
|
}
|
|
|
|
return new HealthCheck(GetType());
|
|
}
|
|
}
|
|
}
|