mirror of
https://github.com/Radarr/Radarr
synced 2025-01-03 22:04:43 +00:00
44 lines
1.2 KiB
C#
44 lines
1.2 KiB
C#
|
using System.Linq;
|
||
|
using NLog;
|
||
|
using NzbDrone.Core.Model;
|
||
|
|
||
|
namespace NzbDrone.Core.DecisionEngine.Specifications
|
||
|
{
|
||
|
public class CustomStartDateSpecification : IFetchableSpecification
|
||
|
{
|
||
|
private readonly Logger _logger;
|
||
|
|
||
|
public CustomStartDateSpecification(Logger logger)
|
||
|
{
|
||
|
_logger = logger;
|
||
|
}
|
||
|
|
||
|
public string RejectionReason
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return "Aired before configured cut-off";
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
public virtual bool IsSatisfiedBy(EpisodeParseResult subject)
|
||
|
{
|
||
|
if (!subject.Series.CustomStartDate.HasValue)
|
||
|
{
|
||
|
_logger.Debug("{0} does not restrict downloads before date.", subject.Series.Title);
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
if (subject.Episodes.Any(episode => episode.AirDate >= subject.Series.CustomStartDate.Value))
|
||
|
{
|
||
|
_logger.Debug("One or more episodes aired after cutoff, downloading.");
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
_logger.Debug("Episodes aired before cutoff date: {0}", subject.Series.CustomStartDate);
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
}
|