using NLog; using NzbDrone.Core.IndexerSearch.Definitions; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.Tv; namespace NzbDrone.Core.DecisionEngine.Specifications.Search { public class DailyEpisodeMatchSpecification : IDecisionEngineSpecification { private readonly Logger _logger; private readonly IEpisodeService _episodeService; public DailyEpisodeMatchSpecification(Logger logger, IEpisodeService episodeService) { _logger = logger; _episodeService = episodeService; } public string RejectionReason { get { return "Episode doesn't match"; } } public bool IsSatisfiedBy(RemoteEpisode remoteEpisode, SearchCriteriaBase searchCriteria) { if (searchCriteria == null) { return true; } var dailySearchSpec = searchCriteria as DailyEpisodeSearchCriteria; if (dailySearchSpec == null) return true; var episode = _episodeService.GetEpisode(dailySearchSpec.SeriesId, dailySearchSpec.Airtime); if (!remoteEpisode.ParsedEpisodeInfo.AirDate.HasValue || remoteEpisode.ParsedEpisodeInfo.AirDate.Value.ToString(Episode.AIR_DATE_FORMAT) != episode.AirDate) { _logger.Trace("Episode AirDate does not match searched episode number, skipping."); return false; } return true; } } }