2013-03-07 01:19:49 +01:00
|
|
|
using NLog;
|
2013-08-12 08:00:40 +02:00
|
|
|
using NzbDrone.Core.Configuration;
|
2013-03-07 01:19:49 +01:00
|
|
|
using NzbDrone.Core.Qualities;
|
|
|
|
using NzbDrone.Core.Tv;
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.DecisionEngine
|
|
|
|
{
|
|
|
|
public interface IQualityUpgradableSpecification
|
|
|
|
{
|
|
|
|
bool IsUpgradable(QualityProfile profile, QualityModel currentQuality, QualityModel newQuality = null);
|
|
|
|
}
|
|
|
|
|
|
|
|
public class QualityUpgradableSpecification : IQualityUpgradableSpecification
|
|
|
|
{
|
2013-08-12 08:00:40 +02:00
|
|
|
private readonly IConfigService _configService;
|
2013-03-07 01:19:49 +01:00
|
|
|
private readonly Logger _logger;
|
|
|
|
|
2013-08-12 08:00:40 +02:00
|
|
|
public QualityUpgradableSpecification(IConfigService configService, Logger logger)
|
2013-03-07 01:19:49 +01:00
|
|
|
{
|
2013-08-12 08:00:40 +02:00
|
|
|
_configService = configService;
|
2013-03-07 01:19:49 +01:00
|
|
|
_logger = logger;
|
|
|
|
}
|
|
|
|
|
|
|
|
public bool IsUpgradable(QualityProfile profile, QualityModel currentQuality, QualityModel newQuality = null)
|
|
|
|
{
|
|
|
|
if (newQuality != null)
|
|
|
|
{
|
|
|
|
if (currentQuality >= newQuality)
|
|
|
|
{
|
|
|
|
_logger.Trace("existing item has better or equal quality. skipping");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2013-08-12 08:00:40 +02:00
|
|
|
if (currentQuality.Quality == newQuality.Quality && newQuality.Proper && _configService.AutoDownloadPropers)
|
2013-03-07 01:19:49 +01:00
|
|
|
{
|
|
|
|
_logger.Trace("Upgrading existing item to proper.");
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (currentQuality.Quality >= profile.Cutoff)
|
|
|
|
{
|
|
|
|
_logger.Trace("Existing item meets cut-off. skipping.");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|