Radarr/src/NzbDrone.Core/HealthCheck/Checks/MonoVersionCheck.cs

73 lines
3.1 KiB
C#
Raw Normal View History

2018-04-21 04:59:31 +00:00
using System;
2014-03-14 10:15:30 +00:00
using NLog;
using NzbDrone.Common.EnvironmentInfo;
namespace NzbDrone.Core.HealthCheck.Checks
{
public class MonoVersionCheck : HealthCheckBase
2014-03-14 10:15:30 +00:00
{
2018-04-21 04:59:31 +00:00
private readonly IPlatformInfo _platformInfo;
2014-03-14 10:15:30 +00:00
private readonly Logger _logger;
2018-04-21 04:59:31 +00:00
public MonoVersionCheck(IPlatformInfo platformInfo, Logger logger)
2014-03-14 10:15:30 +00:00
{
2018-04-21 04:59:31 +00:00
_platformInfo = platformInfo;
2014-03-14 10:15:30 +00:00
_logger = logger;
}
public override HealthCheck Check()
2014-03-14 10:15:30 +00:00
{
2018-04-21 04:59:31 +00:00
if (!PlatformInfo.IsMono)
2014-03-14 10:15:30 +00:00
{
return new HealthCheck(GetType());
2014-03-14 10:15:30 +00:00
}
2018-04-21 04:59:31 +00:00
var monoVersion = _platformInfo.Version;
2014-03-14 10:15:30 +00:00
// Known buggy Mono versions
2018-04-21 04:59:31 +00:00
if (monoVersion == new Version("4.4.0") || monoVersion == new Version("4.4.1"))
{
_logger.Debug("Mono version {0}", monoVersion);
return new HealthCheck(GetType(), HealthCheckResult.Error,
$"Currently installed Mono version {monoVersion} has a bug that causes issues connecting to indexers/download clients. You should upgrade to a higher version",
"#currently-installed-mono-version-is-old-and-unsupported");
2018-04-21 04:59:31 +00:00
}
// Currently best stable Mono version (5.18 gets us .net 4.7.2 support)
var bestVersion = new Version("5.20");
var targetVersion = new Version("5.18");
if (monoVersion >= targetVersion)
2018-04-21 04:59:31 +00:00
{
_logger.Debug("Mono version is {0} or better: {1}", targetVersion, monoVersion);
2018-04-21 04:59:31 +00:00
return new HealthCheck(GetType());
}
// Stable Mono versions
var stableVersion = new Version("5.16");
if (monoVersion >= stableVersion)
{
_logger.Debug("Mono version is {0} or better: {1}", stableVersion, monoVersion);
return new HealthCheck(GetType(), HealthCheckResult.Notice,
$"Currently installed Mono version {monoVersion} is supported but upgrading to {bestVersion} is recommended.",
"#currently-installed-mono-version-is-supported-but-upgrading-is-recommended");
}
// Old but supported Mono versions, there are known bugs
var supportedVersion = new Version("5.4");
if (monoVersion >= supportedVersion)
{
_logger.Debug("Mono version is {0} or better: {1}", supportedVersion, monoVersion);
return new HealthCheck(GetType(), HealthCheckResult.Warning,
$"Currently installed Mono version {monoVersion} is supported but has some known issues. Please upgrade Mono to version {bestVersion}.",
"#currently-installed-mono-version-is-supported-but-upgrading-is-recommended");
}
return new HealthCheck(GetType(), HealthCheckResult.Error,
$"Currently installed Mono version {monoVersion} is old and unsupported. Please upgrade Mono to version {bestVersion}.",
"#currently-installed-mono-version-is-old-and-unsupported");
}
2016-12-09 06:54:15 +00:00
public override bool CheckOnSchedule => false;
2014-03-14 10:15:30 +00:00
}
}