mirror of
https://github.com/Sonarr/Sonarr
synced 2024-12-27 10:17:47 +00:00
45 lines
1.6 KiB
C#
45 lines
1.6 KiB
C#
using System.Linq;
|
|
using NLog;
|
|
using NzbDrone.Core.History;
|
|
using NzbDrone.Core.Tv;
|
|
using NzbDrone.Core.Model;
|
|
using NzbDrone.Core.Providers;
|
|
|
|
namespace NzbDrone.Core.DecisionEngine
|
|
{
|
|
public class UpgradeHistorySpecification
|
|
{
|
|
private readonly IEpisodeService _episodeService;
|
|
private readonly HistoryService _historyService;
|
|
private readonly QualityUpgradeSpecification _qualityUpgradeSpecification;
|
|
private static readonly Logger logger = LogManager.GetCurrentClassLogger();
|
|
|
|
public UpgradeHistorySpecification(IEpisodeService episodeService, HistoryService historyService, QualityUpgradeSpecification qualityUpgradeSpecification)
|
|
{
|
|
_episodeService = episodeService;
|
|
_historyService = historyService;
|
|
_qualityUpgradeSpecification = qualityUpgradeSpecification;
|
|
}
|
|
|
|
public UpgradeHistorySpecification()
|
|
{
|
|
|
|
}
|
|
|
|
public virtual bool IsSatisfiedBy(EpisodeParseResult subject)
|
|
{
|
|
foreach (var episode in subject.Episodes)
|
|
{
|
|
var bestQualityInHistory = _historyService.GetBestQualityInHistory(subject.Series.OID, episode.SeasonNumber, episode.EpisodeNumber);
|
|
if (bestQualityInHistory != null)
|
|
{
|
|
logger.Trace("Comparing history quality with report. History is {0}", bestQualityInHistory);
|
|
if (!_qualityUpgradeSpecification.IsSatisfiedBy(bestQualityInHistory, subject.Quality, subject.Series.QualityProfile.Cutoff))
|
|
return false;
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|
|
}
|