using System.Linq; using NLog; using NzbDrone.Core.Datastore; using NzbDrone.Core.Qualities; using NzbDrone.Core.Tv; using NzbDrone.Core.Model; using NzbDrone.Core.Providers; namespace NzbDrone.Core.DecisionEngine { public class AcceptableSizeSpecification { private readonly QualitySizeService _qualityTypeProvider; private readonly IEpisodeService _episodeService; private static readonly Logger logger = LogManager.GetCurrentClassLogger(); public AcceptableSizeSpecification(QualitySizeService qualityTypeProvider, IEpisodeService episodeService) { _qualityTypeProvider = qualityTypeProvider; _episodeService = episodeService; } public AcceptableSizeSpecification() { } public virtual bool IsSatisfiedBy(EpisodeParseResult subject) { logger.Trace("Beginning size check for: {0}", subject); if(subject.Quality.Quality == Quality.RAWHD) { logger.Trace("Raw-HD release found, skipping size check."); return true; } var qualityType = _qualityTypeProvider.Get((int)subject.Quality.Quality); if (qualityType.MaxSize == 0) { logger.Trace("Max size is 0 (unlimited) - skipping check."); return true; } var maxSize = qualityType.MaxSize.Megabytes(); var series = subject.Series; //Multiply maxSize by Series.Runtime maxSize = maxSize * series.Runtime; //Multiply maxSize by the number of episodes parsed (if EpisodeNumbers is null it will be treated as a single episode) //TODO: is this check really necessary? shouldn't we blowup? if (subject.EpisodeNumbers != null) maxSize = maxSize * subject.EpisodeNumbers.Count; //Check if there was only one episode parsed //and it is the first or last episode of the season if (subject.EpisodeNumbers != null && subject.EpisodeNumbers.Count == 1 && _episodeService.IsFirstOrLastEpisodeOfSeason(series.Id, subject.SeasonNumber, subject.EpisodeNumbers[0])) { maxSize = maxSize * 2; } //If the parsed size is greater than maxSize we don't want it if (subject.Size > maxSize) { logger.Trace("Item: {0}, Size: {1} is greater than maximum allowed size ({2}), rejecting.", subject, subject.Size, maxSize); return false; } logger.Trace("Item: {0}, meets size contraints.", subject); return true; } } }